[
  {
    "context": [
      "I am using `jq` to count number of keys file value have in this json object.",
      "here i get output 4 whereas there is only 2 keys a,b",
      "how do i get arr only have two elements `a` and `b`.?",
      "Try this instead:",
      "jq -r '.file | keys | .[]' jsonfile.json",
      "Output:",
      "a",
      "b"
    ],
    "utterance": "List the keys of the 'file' object so that each key is a separate element in a bash array.",
    "expressions": [
      ".file | keys | .[]"
    ],
    "data": [
      {
        "input": {
          "file": {
            "a": 1,
            "b": 2
          }
        },
        "output": [
          "a",
          "b"
        ]
      }
    ],
    "identifier": 32809062
  },
  {
    "context": [
      "One way to convert a JSON array to a stream of newline-delimited JSON entities is to use jq with the -c option, e.g.",
      "$ jq -c \".[]\"",
      "Input:",
      "[[1,2], 3, {\"4\":5}]",
      "Output:",
      "[1,2]",
      "3",
      "{\"4\":5}\""
    ],
    "utterance": "Output each element of the top-level array, in compact format, as a separate line.",
    "expressions": [
      ".[]",
      "-c .[]"
    ],
    "data": [
      {
        "input": [
          [
            1,
            2
          ],
          3,
          {
            "4": 5
          }
        ],
        "output": [
          "[1,2]",
          "3",
          "{\"4\":5}"
        ]
      }
    ],
    "identifier": 32750745
  },
  {
    "context": [
      "stream = os.popen(\"curl -s 'http://someip/json.htm?type=devices&rid=7'| jq -r .result[].Data\")",
      "sh: 1: jq: not found",
      "One solution would be to \"hardwire\" the pathname of jq into your call to jq."
    ],
    "utterance": "Query the Data fields from all objects in the result array returned by the given HTTP request where type is devices and rid is 7.",
    "expressions": [
      ".result[].Data"
    ],
    "identifier": 32837827
  },
  {
    "identifier": 32911446
  },
  {
    "context": [
      "Now I would like, for each request, a column with all the URLs and the next columns with the corresponding Content-Encoding and Content-Type HTTP header values returned in the response/headers section.",
      "How can I do that?",
      "There is a difficulty here because the headers may not be returned in the same order by the HTTP server.",
      "You could use a filter like this:",
      "[ \"url\", \"content-type\", \"content-encoding\" ],\n(.log.entries[] | [\n    .request.url,\n    ((.response.headers[] | select(.name == \"Content-Type\").value) // \"\"),\n    ((.response.headers[] | select(.name == \"Content-Encoding\").value) // \"\")\n])\n| @csv",
      "The key here is that for the content type and encoding, you need to perform a search for those headers separately if you want to control the order they appear.  Then from there, you just need to format it in such a way it could be output as csv."
    ],
    "utterance": "List each request URL with its corresponding Content-Type and Content-Encoding response header values, with a column for each.",
    "expressions": [
      "[ \"url\", \"content-type\", \"content-encoding\" ],\n(.log.entries[] | [\n    .request.url,\n    ((.response.headers[] | select(.name == \"Content-Type\").value) // \"\"),\n    ((.response.headers[] | select(.name == \"Content-Encoding\").value) // \"\")\n])\n| @csv"
    ],
    "identifier": 32870341
  },
  {
    "context": [
      "now categories is stringify object...i need to parse it and convert it into json object.",
      "*fromjson* is your friend:",
      "$ jq '.categoriesListArr | fromjson' detail.json",
      "Or, if you want to retain the original structure:",
      "$ jq '.categoriesListArr |= fromjson' detail.json"
    ],
    "utterance": "Convert the value of the 'categoriesListArr' field, which is a stringified object, into a structured object.",
    "expressions": [
      ".categoriesListArr | fromjson",
      ".categoriesListArr |= fromjson"
    ],
    "data": [
      {
        "input": {
          "logo": {
            "name": "logo.png",
            "type": "image/jpeg",
            "tmp_name": "C:\\xampp\\tmp\\php8B97.tmp",
            "error": 0,
            "size": 110290
          },
          "template": "template1",
          "firstname": "a",
          "lastname": "a",
          "username": "a",
          "password": "aa",
          "email": "a",
          "categoriesListArr": "{\"Women\":[\"All footwear\",\"All footwear\",\"All Clothing\",\"All Clothing\",\"All Watches\",\"All Watches\",\"All Sunglasses\",\"All Sunglasses\"],\"Men\":[\"All Mens Accessories\",\"All Bags,Belts And wallets\",\"All Fragrances\",\"All Grooming and wellness\"]}",
          "aboutUs": "aa",
          "contactUs": "78787878878787",
          "deliveryInfo": "aa",
          "privacyPolicy": "aa",
          "t&d": "aa"
        },
        "output": {
          "Women": [
            "All footwear",
            "All footwear",
            "All Clothing",
            "All Clothing",
            "All Watches",
            "All Watches",
            "All Sunglasses",
            "All Sunglasses"
          ],
          "Men": [
            "All Mens Accessories",
            "All Bags,Belts And wallets",
            "All Fragrances",
            "All Grooming and wellness"
          ]
        }
      }
    ],
    "identifier": 32629301
  },
  {
    "context": [
      "Is it possible to make Jq print newline instead of the \\n character sequence as seen in the value of `.stack_trace`?",
      "Sure! Using the `-r` option, jq will print string contents directly to the terminal instead of as JSON escaped strings.",
      "jq -r '.stack_trace'",
      "The input as originally given isn't quite valid JSON, and it's not clear precisely what the desired output is, but the following might be of interest.",
      "Output:",
      "\"stack_trace\": \"ERROR LALALLA\nERROR INFO NANANAN\nSOME MORE ERROR INFO\nBABABABABABBA BABABABA ABABBABAA BABABABAB\n\""
    ],
    "utterance": "Obtain the value of the stack_trace field with real newlines instead of the escaped \\n sequences.",
    "expressions": [
      ".stack_trace",
      "-r .stack_trace"
    ],
    "data": [
      {
        "input": {
          "@timestamp": "2015-09-22T10:54:35.449+02:00",
          "@version": 1,
          "HOSTNAME": "server1.example",
          "level": "WARN",
          "level_value": 30000,
          "logger_name": "server1.example.adapter",
          "message": "message",
          "stack_trace": "ERROR LALALLLA\\nERROR INFO NANANAN\\nSOME MORE ERROR INFO\\nBABABABABABBA BABABABA ABABBABAA BABABABAB\\n"
        },
        "output": "ERROR LALALLLA\nERROR INFO NANANAN\nSOME MORE ERROR INFO\nBABABABABABBA BABABABA ABABBABAA BABABABAB\n"
      }
    ],
    "identifier": 32715008
  },
  {
    "context": [
      "I have a *JSON* object like \r\n\r\n     {\r\n      \"Men\": [\r\n        \"All Clothing\",\r\n        \"All Clothing\",\r\n        \"All footwear\",\r\n        \"All footwear\",\r\n        \"All Watches\",\r\n        \"All Watches\",\r\n        \"All Sunglasses\",\r\n        \"All Sunglasses\"\r\n      ],\r\n      \"Electronics\": [\r\n        \"Mobiles\",\r\n        \"Tablets\",\r\n        \"Wearable Smart Devices\",\r\n        \"Mobile Accessories\",\r\n        \"Headphones and headsets\",\r\n        \"Tablet Accessories\",\r\n        \"Computer Accessories\",\r\n        \"Televisions\",\r\n        \"Large Appliances\",\r\n        \"Small Appliances\",\r\n        \"Kitchen Appliances\",\r\n        \"Personal Care\",\r\n        \"Audio and video\",\r\n        \"Laptop\"\r\n      ],\r\n      \"Women\": [\r\n        \"Ethnic wear\",\r\n        \"Western wear\",\r\n        \"Lingerie & Sleep Wear\",\r\n        \"All Bags, Belts & Wallets\",\r\n        \"All jewellery\",\r\n        \"All Perfumes\",\r\n        \"Spectacle Frames\",\r\n        \"Beauty & Personal Care\",\r\n        \"The International Beauty Shop\"\r\n      ]\r\n    }\r\n",
      "I want to get key value pair from this object.m using jq filter but it doesnot work.",
      "jq keys <<<\"$categories\"",
      "printf '%s\\n' \"$categories\" | jq keys",
      "keys=$(jq 'keys' <<<\"$categories\")"
    ],
    "utterance": "List the top-level keys of the object provided in the variable categories.",
    "expressions": [
      "jq 'keys'",
      "jq keys"
    ],
    "data": [
      {
        "input": {
          "Men": [
            "All Clothing",
            "All Clothing",
            "All footwear",
            "All footwear",
            "All Watches",
            "All Watches",
            "All Sunglasses",
            "All Sunglasses"
          ],
          "Electronics": [
            "Mobiles",
            "Tablets",
            "Wearable Smart Devices",
            "Mobile Accessories",
            "Headphones and headsets",
            "Tablet Accessories",
            "Computer Accessories",
            "Televisions",
            "Large Appliances",
            "Small Appliances",
            "Kitchen Appliances",
            "Personal Care",
            "Audio and video",
            "Laptop"
          ],
          "Women": [
            "Ethnic wear",
            "Western wear",
            "Lingerie & Sleep Wear",
            "All Bags, Belts & Wallets",
            "All jewellery",
            "All Perfumes",
            "Spectacle Frames",
            "Beauty & Personal Care",
            "The International Beauty Shop"
          ]
        },
        "output": [
          "Men",
          "Electronics",
          "Women"
        ]
      }
    ],
    "identifier": 32710114
  },
  {
    "context": [
      "I have a shell variable which contains json as follows",
      "VAL=$(echo \"$RET\" | jq \".pending[$j].value\")",
      "curl -X POST -H \"$CONTENT_HEADER\" -H \"$AUTH_HEADER\" http://localhost:8080/testApi -d $VAL",
      "The shell is interpreting it as several arguments. Either quote the expansion (as in `-d \"$VAL\"`)"
    ],
    "utterance": "Extract a value located at .pending[j].value so it can be passed as a single string argument in a POST request body.",
    "expressions": [
      ".pending[$j].value"
    ],
    "identifier": 32934683
  },
  {
    "context": [
      "I\u2019d like to get details for all non-management employees so that the desired output looks like this:\r\n\r\n    {\r\n      \"number\": \"102\",\r\n      \"name\": \"jane doe\",\r\n      \"login\": \"jane\"\r\n    }\r\n    {\r\n      \"number\": \"103\",\r\n      \"name\": \"john doe\",\r\n      \"login\": \"john\"\r\n    }",
      "Using `from_entries`, this worked for me:\r\n\r\n    $ jq '.employees[] | {number: .number, tags: .tags | from_entries} | select(.tags.management==\"no\") | {number: .number, name: .tags.name, login: .tags.login}' input",
      "The following is a slightly more succinct solution:\r\n\r\n    .employees[]\r\n    | .tags |= from_entries\r\n    | select(.tags.management == \"no\")\r\n    | {number, \"name\": .tags.name, \"login\": .tags.login}",
      "Here is another solution which uses [from_entries](https://github.com/stedolan/jq/blob/master/src/builtin.jq#L24)\r\n\r\n      .employees[]\r\n    | {number} + (.tags | from_entries)\r\n    | if .management == \"no\" then {number, name, login} else empty end"
    ],
    "utterance": "Extract each employee's number, name, and login where the management tag equals \"no\".",
    "expressions": [
      ".employees[] | {number: .number, tags: .tags | from_entries} | select(.tags.management==\"no\") | {number: .number, name: .tags.name, login: .tags.login}",
      ".employees[] | .tags |= from_entries | select(.tags.management == \"no\") | {number, \"name\": .tags.name, \"login\": .tags.login}",
      ".employees[] | {number} + (.tags | from_entries) | if .management == \"no\" then {number, name, login} else empty end"
    ],
    "data": [
      {
        "input": {
          "employees": [
            {
              "number": "101",
              "tags": [
                {
                  "value": "yes",
                  "key": "management"
                },
                {
                  "value": "joe",
                  "key": "login"
                },
                {
                  "value": "joe blogs",
                  "key": "name"
                }
              ]
            },
            {
              "number": "102",
              "tags": [
                {
                  "value": "no",
                  "key": "management"
                },
                {
                  "value": "jane",
                  "key": "login"
                },
                {
                  "value": "jane doe",
                  "key": "name"
                }
              ]
            },
            {
              "number": "103",
              "tags": [
                {
                  "value": "no",
                  "key": "management"
                },
                {
                  "value": "john",
                  "key": "login"
                },
                {
                  "value": "john doe",
                  "key": "name"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "number": "102",
            "name": "jane doe",
            "login": "jane"
          },
          {
            "number": "103",
            "name": "john doe",
            "login": "john"
          }
        ]
      }
    ],
    "identifier": 32675229
  },
  {
    "context": [
      "I\u2019d like to display value of Name (\"CC\" in example above). If this value is missing \"N/A\" should be displayed.",
      "Use the alternative operator, `//`.",
      "`jq -r '.Tags[] | select(.Key == \"Name\") | .Value // \"N/A\"'`",
      "jq -r '.Tags | from_entries | .Name // \"N/A\"'",
      "jq -r '.Tags | map({key:.Key, value:.Value}) | from_entries | .Name // \"N/A\"'"
    ],
    "utterance": "Display the value for Key equal to Name, or output N/A if it is missing.",
    "expressions": [
      ".Tags[] | select(.Key == \"Name\") | .Value // \"N/A\"",
      ".Tags | from_entries | .Name // \"N/A\"",
      ".Tags | map({key:.Key, value:.Value}) | from_entries | .Name // \"N/A\""
    ],
    "data": [
      {
        "input": {
          "Tags": [
            {
              "Key": "Team",
              "Value": "AA"
            },
            {
              "Key": "Division",
              "Value": "BB"
            },
            {
              "Key": "Name",
              "Value": "CC"
            }
          ]
        },
        "output": "CC"
      },
      {
        "input": {
          "Tags": [
            {
              "Key": "Team",
              "Value": "AA"
            },
            {
              "Key": "Division",
              "Value": "BB"
            }
          ]
        },
        "output": "N/A"
      }
    ],
    "identifier": 32931471
  },
  {
    "context": [
      "My JSON input:\r\n\r\n      {  \"Key\": \"Team\",     \"Value\": \"AA\" }\r\n      {  \"Key\": \"Division\", \"Value\": \"BB\" }\r\n\r\nDesired output:\r\n\r\n    [\r\n      {  \"Key\": \"Team\",     \"Value\": \"AA\" },\r\n      {  \"Key\": \"Division\", \"Value\": \"BB\" }\r\n    ]\r\n\r\nI cannot use the `--slurp` option because I'm in a middle of complex jq code.",
      "If your input really is irredeemably a stream, and if you cannot use the slurp option, then the simplest would probably be to use jq 1.5's `inputs` filter, along the lines of:\r\n```\r\njq -n '[inputs]'\r\n```",
      "If you don't use the -n option, then the first JSON entity won't be seen by `inputs`.  If you cannot use the -n option, then use `[., inputs]`",
      "I think all you need is to use the jq array constructor syntax.  I.e. enclose whatever complex expression you have that generates the stream in a pair of `[ ]`",
      "[ some_complex_expression ]"
    ],
    "utterance": "Wrap a stream of objects in array brackets to collect them into a single array, without using the slurp option.",
    "expressions": [
      "[inputs]",
      "[., inputs]",
      "[ some_complex_expression ]"
    ],
    "data": [
      {
        "input": [
          {
            "Key": "Team",
            "Value": "AA"
          },
          {
            "Key": "Division",
            "Value": "BB"
          }
        ],
        "output": [
          {
            "Key": "Team",
            "Value": "AA"
          },
          {
            "Key": "Division",
            "Value": "BB"
          }
        ]
      }
    ],
    "identifier": 32936439
  },
  {
    "context": [
      "I have a json and at the moment using select to get only the data which match one condition, I need to filter based on more conditions.",
      ".[] | select((.processedBarsVolume <= 5) && .processedBars > 0)",
      "`jq` supports the normal [Boolean operators and/or/not](https://jqlang.github.io/jq/manual/#and-or-not), so it would look like:",
      ".[] | select((.processedBarsVolume <= 5) and .processedBars > 0)"
    ],
    "utterance": "Filter objects where processedBarsVolume is less than or equal to 5 and processedBars is greater than 0.",
    "expressions": [
      ".[] | select((.processedBarsVolume <= 5) and .processedBars > 0)",
      ".[] | select((.processedBarsVolume <= 5) && .processedBars > 0)"
    ],
    "identifier": 33057420
  },
  {
    "context": [
      "I want to use `jq` to group the three records by tag Value where the Key = \"Name\". The result would be two arrays, one with two records in it and one with one.",
      "map( .Tags |= from_entries ) | group_by(.Tags.Name)",
      "map( .Tags |= from_entries ) | group_by(.Tags.Name)\n| map(map( .Tags |= to_entries))",
      "def KV: map( {Key: .key, Value: .value} );\n\nmap( .Tags |= from_entries ) | group_by(.Tags.Name)\n| map(map( .Tags |= (to_entries | KV)))"
    ],
    "utterance": "Group the top-level array into subarrays where records have the same 'Value' for the tag whose Key is 'Name'.",
    "expressions": [
      "map( .Tags |= from_entries ) | group_by(.Tags.Name)",
      "map( .Tags |= from_entries ) | group_by(.Tags.Name)\n| map(map( .Tags |= to_entries))",
      "def KV: map( {Key: .key, Value: .value} );\nmap( .Tags |= from_entries ) | group_by(.Tags.Name)\n| map(map( .Tags |= (to_entries | KV)))"
    ],
    "data": [
      {
        "input": [
          {
            "Name": "one",
            "Tags": [
              {
                "Key": "Name",
                "Value": "important"
              },
              {
                "Key": "OtherTag",
                "Value": "irrelevant"
              }
            ]
          },
          {
            "Name": "two",
            "Tags": [
              {
                "Key": "OtherTag",
                "Value": "irrelevant2"
              },
              {
                "Key": "Name",
                "Value": "important"
              }
            ]
          },
          {
            "Name": "three",
            "Tags": [
              {
                "Key": "Name",
                "Value": "important2"
              },
              {
                "Key": "OtherTag",
                "Value": "irrelevant3"
              }
            ]
          }
        ],
        "output": [
          [
            {
              "Name": "one",
              "Tags": [
                {
                  "Key": "Name",
                  "Value": "important"
                },
                {
                  "Key": "OtherTag",
                  "Value": "irrelevant"
                }
              ]
            },
            {
              "Name": "two",
              "Tags": [
                {
                  "Key": "OtherTag",
                  "Value": "irrelevant2"
                },
                {
                  "Key": "Name",
                  "Value": "important"
                }
              ]
            }
          ],
          [
            {
              "Name": "three",
              "Tags": [
                {
                  "Key": "Name",
                  "Value": "important2"
                },
                {
                  "Key": "OtherTag",
                  "Value": "irrelevant3"
                }
              ]
            }
          ]
        ]
      }
    ],
    "identifier": 32897445
  },
  {
    "context": [
      "I have jq command like this:\r\n\r\n    jq --arg ts \"$TS\" '.Date = $ts, .Marker.Date = $ts, .InfoFromTerminator.Timestamp = $ts'\r\n\r\nbut it appears to only replace the last item keeping the previous two as is. How do I rewrite the query to replace for all 3 parameters?",
      "Changing multiple elements can be done by piping from one filter/assignment in to the next as follows:\r\n\r\n    jq --arg ts \"$TS\" '.Date = $ts | .Marker.Date = $ts | .InfoFromTerminator.Timestamp = $ts'",
      "You can also use comma to assign a collection of properties to the same value:\r\n\r\n    jq --arg ts \"$TS\" '(.StartDate, .EndDate) = $ts'\r\n\r\nThis takes the list of path references on the left-hand side and updates them all to the new value."
    ],
    "utterance": "Update .Date, .Marker.Date, and .InfoFromTerminator.Timestamp to the same value provided by the variable $ts.",
    "expressions": [
      ".Date = $ts | .Marker.Date = $ts | .InfoFromTerminator.Timestamp = $ts",
      "(.Date, .Marker.Date, .InfoFromTerminator.Timestamp) = $ts"
    ],
    "identifier": 33075323
  },
  {
    "context": [
      "I want to return something like this:",
      "    [",
      "      {",
      "        \"foo\": \"false\"",
      "      },",
      "      {",
      "        \"bar\": \"true\"",
      "      }",
      "    ]",
      "You can't really use `to_entries` here, that creates an object out of an array of key/value objects. You're trying to map a key/value object to another object. Just map it directly.",
      "    map({ (.key): .value.sub })"
    ],
    "utterance": "Return an array of objects where each object maps the original 'key' value to the value of its nested 'sub' attribute.",
    "expressions": [
      "map({ (.key): .value.sub })"
    ],
    "data": [
      {
        "input": [
          {
            "key": "foo",
            "value": {
              "sub": false
            }
          },
          {
            "key": "bar",
            "value": {
              "sub": true
            }
          }
        ],
        "output": [
          {
            "foo": false
          },
          {
            "bar": true
          }
        ]
      }
    ],
    "identifier": 33080405
  },
  {
    "context": [
      "I have a 2MB json file that is only **all in one line** and now I get an error using `jq`:",
      "$ jq .<nodes.json",
      "parse error: Invalid literal at line 1, column 377140",
      "cut the file into more lines with",
      "cat nodes.json|cut -f 1- -d} --output-delimiter=$'}\\n'>/tmp/a.json",
      "and analyse `/tmp/a.json` with, then you get an error with line nr:",
      "use `less -N /tmp/a.json` to find that line"
    ],
    "utterance": "Split a large single-line file at each closing curly brace and re-analyze to identify the parse error position by line number.",
    "expressions": [
      "cat nodes.json | cut -f 1- -d} --output-delimiter=$'}\n' >/tmp/a.json",
      "jq . /tmp/a.json"
    ],
    "identifier": 33091762
  },
  {
    "context": [
      "I want a JSON files with the keys, {\"key1\",\"key2\"} each having several values and are written in a txt file. The txt file for each key looks like this:",
      "key1.txt:\nval1\nval2\nval3\n..",
      "create a json file that has the following structure:\n{\n    key1:\n    [ \"val1\"\n      \"val2\"\n       ...\n    ]\n\n    key2:\n    [ \"val1\"\n      \"val2\"\n       ...\n    ]\n}",
      "$ jq --argjson key1 \"$(jq -R '.' key1.txt | jq -s '.')\" \\\n     --argjson key2 \"$(jq -R '.' key2.txt | jq -s '.')\" \\\n     -n '{ key1: $key1, key2: $key2 }'",
      "for f in *.txt; do\n  <\"$f\" jq -nR --arg key \"${f%.txt}\" '{$key,value:[inputs]}';\ndone | jq -s 'from_entries'"
    ],
    "utterance": "Combine the contents of key1.txt and key2.txt, where each file contains one value per line, into an object mapping each key to an array of its values.",
    "expressions": [
      "jq --argjson key1 \"$(jq -R '.' key1.txt | jq -s '.')\" --argjson key2 \"$(jq -R '.' key2.txt | jq -s '.')\" -n '{ key1: $key1, key2: $key2 }'",
      "for f in *.txt; do <\"$f\" jq -nR --arg key \"${f%.txt}\" '{$key, value: [inputs]}'; done | jq -s 'from_entries'"
    ],
    "data": [
      {
        "input": {
          "key1.txt": "val1\nval2\nval3",
          "key2.txt": "valA\nvalB"
        },
        "output": {
          "key1": [
            "val1",
            "val2",
            "val3"
          ],
          "key2": [
            "valA",
            "valB"
          ]
        }
      }
    ],
    "identifier": 33021152
  },
  {
    "identifier": 33184780
  },
  {
    "context": [
      "You need to supply a filter as an argument. To pass the JSON through unmodified other than the pretty printing `jq` provides by default, use the identity filter `.`:",
      "curl -s https://api.github.com/users/octocat/repos | jq '.' | cat"
    ],
    "utterance": "Pass all elements from the input stream through unchanged, producing pretty-printed output.",
    "expressions": [
      "."
    ],
    "identifier": 33247228
  },
  {
    "context": [
      "Given this input:",
      "I would like to have",
      "Since you want to set the null datasources of the panels to `\"mydb\"`, you could do this:",
      "$ jq '.rows[].panels[].datasource //= \"mydb\"' input.json",
      "If you want to update any `datasource` property on any object at any level, you could use `..` to recursively search for them.",
      "$ jq '(.. | select(objects | has(\"datasource\"))).datasource //= \"mydb\"' input.json",
      "Here is a solution which uses **tostream**, **reduce** and **setpath** to set any leaf `datasource` attribute whose value is `null` to `\"mydb\"`.",
      "reduce (tostream|select(length==2)) as [$p,$v] (\n  .\n; if $p[-1] == \"datasource\" and $v == null then setpath($p; \"mydb\") else . end\n)"
    ],
    "utterance": "Replace every 'datasource' property set to null anywhere in the input with the value 'mydb'.",
    "expressions": [
      ".rows[].panels[].datasource //= \"mydb\"",
      "(.. | select(objects | has(\"datasource\"))).datasource //= \"mydb\"",
      "reduce (tostream|select(length==2)) as [$p,$v] (\n  .\n; if $p[-1] == \"datasource\" and $v == null then setpath($p; \"mydb\") else . end\n)"
    ],
    "data": [
      {
        "input": {
          "id": null,
          "rows": [
            {
              "panels": [
                {
                  "title": "Panel1",
                  "datasource": null
                },
                {
                  "title": "Panel2",
                  "datasource": null
                }
              ]
            }
          ]
        },
        "output": {
          "id": null,
          "rows": [
            {
              "panels": [
                {
                  "title": "Panel1",
                  "datasource": "mydb"
                },
                {
                  "title": "Panel2",
                  "datasource": "mydb"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 33128365
  },
  {
    "context": [
      "I want to convert it with jq to this:\r\n\r\n        [\r\n          {\r\n            \"id\": \"36143\",\r\n            \"name\": \"ST card\"\r\n            \"value\": \"B-Serious\"\r\n          },\r\n          {\r\n            \"id\": \"36144\",\r\n            \"name\": \"AT card\"\r\n            \"value\": \"B-Serious\"\r\n          },\r\n          {\r\n            \"id\": \"36145\",\r\n            \"name\": \"ST card\"\r\n            \"value\": \"C-Limited\"\r\n          }\r\n        ]\r\n\nNote that the first object has 2 versions, and the same severity.",
      "You're combining the different versions with the corresponding severity.  Here's how you could do that.\n\n    map(.fields | (.versions[] | { id, name }) + { value: .severity.value })"
    ],
    "utterance": "For each object, extract all versions, and for each version output its id and name along with the corresponding severity value.",
    "expressions": [
      "map(.fields | (.versions[] | {id, name}) + {value: .severity.value})"
    ],
    "data": [
      {
        "input": [
          {
            "fields": {
              "versions": [
                {
                  "id": "36143",
                  "name": "ST card"
                },
                {
                  "id": "36144",
                  "description": "Acceptance test card",
                  "name": "AT card"
                }
              ],
              "severity": {
                "value": "B-Serious",
                "id": "14231"
              }
            }
          },
          {
            "fields": {
              "versions": [
                {
                  "id": "36145",
                  "name": "ST card"
                }
              ],
              "severity": {
                "value": "C-Limited",
                "id": "14235"
              }
            }
          }
        ],
        "output": [
          {
            "id": "36143",
            "name": "ST card",
            "value": "B-Serious"
          },
          {
            "id": "36144",
            "name": "AT card",
            "value": "B-Serious"
          },
          {
            "id": "36145",
            "name": "ST card",
            "value": "C-Limited"
          }
        ]
      }
    ],
    "identifier": 33148557
  },
  {
    "context": [
      "I'm using JQ https://stedolan.github.io/jq/ to work in bash with my json and when I read the json is throwing me an error",
      "Since my json has some comments",
      "Remove them; JSON does not support comments.",
      "JSON and thus jq do not support comments (in the usual sense) in JSON input.",
      "Can be stripped out using sed, eg to remove lines beginning with '//':\n\n    cat test.json | sed 's/^ *\\/\\/.*//' | jq <commands>",
      "With this sed, you can remove:\n1. Empty lines\n2. Comments, even in the format \"key\": \"value\" //my comment\"\n\nEventually, json will be output, which can be processed without problems using jq\n\n```sed '/^[[:blank:]]*#/d;s/\\/\\/.*//' my.json | jq '.<your_block>'```"
    ],
    "utterance": "Filter out lines with // comments and then select a block from the cleaned data where comments have been removed, including both full-line and inline comments.",
    "expressions": [
      "sed '/^[[:blank:]]*#/d;s/\\/\\/.*//' my.json | jq '.<your_block>'",
      "cat test.json | sed 's/^ *\\/\\/.*//' | jq <commands>"
    ],
    "data": [
      {
        "input": "// comment\n{\n  \"foo\": 42 // inline comment\n}\n",
        "output": "{\n  \"foo\": 42\n}\n"
      }
    ],
    "identifier": 33352930
  },
  {
    "context": [
      "Using jq (1.5), I want to print the username that matches current-user.",
      "cat 99 | jq -r '.\"current-user\" as $foo | .users[] | select(.name == $foo).user'",
      "foreach .users[] as $u (\n     .\"current-user\"\n   ; .\n   ; if . == $u.name then $u.user.username else empty end\n)"
    ],
    "utterance": "Find the username value for the user whose name matches the value of current-user.",
    "expressions": [
      ".\"current-user\" as $foo | .users[] | select(.name == $foo).user.username",
      "foreach .users[] as $u (.\"current-user\"; .; if . == $u.name then $u.user.username else empty end)"
    ],
    "data": [
      {
        "input": {
          "users": [
            {
              "name": "tester-01",
              "user": {
                "username": "tester01"
              }
            },
            {
              "name": "tester-02",
              "user": {
                "username": "tester02"
              }
            }
          ],
          "current-user": "tester-02"
        },
        "output": "tester02"
      }
    ],
    "identifier": 33397134
  },
  {
    "context": [
      "I want to read in several files (index.html, style.css, main.js) to create a JSON payload for upload.",
      "$ jq -Rs '{ html: . }' index.html",
      "This ought to work for you (requires jq 1.5):\n\n    jq --null-input --raw-input \\\n      'reduce inputs as $line ({}; .[input_filename] += [$line]) | map_values(join(\"\\n\"))' \\\n      index.html style.css main.js",
      "Example:\n\n    $ jq --null-input --raw-input \\\n      'reduce inputs as $line ({}; .[input_filename] += [$line]) | map_values(join(\"\\n\"))' \\\n      test1.txt test2.txt\n    {\n      \"test1.txt\": \"foo\\nbar\\nbaz\",\n      \"test2.txt\": \"qux\\nquux\\nquuux\"\n    }",
      "(jq -Rs '{ html: . }' index.html; \\\n jq -Rs '{ javascript: . }' main.js; \\\n jq -Rs '{ css: . }' style.css) |\\\n jq -s add"
    ],
    "utterance": "Create an object mapping file names to their entire text content for multiple files (index.html, style.css, main.js), treating each file's contents as a single string.",
    "expressions": [
      "jq --null-input --raw-input 'reduce inputs as $line ({}; .[input_filename] += [$line]) | map_values(join(\"\\n\"))' index.html style.css main.js",
      "(jq -Rs '{ html: . }' index.html; jq -Rs '{ javascript: . }' main.js; jq -Rs '{ css: . }' style.css) | jq -s add"
    ],
    "data": [
      {
        "input": {
          "index.html": "<html>Hello</html>\n",
          "style.css": "body { background: #fff; }\n",
          "main.js": "console.log('hello');\n"
        },
        "output": {
          "index.html": "<html>Hello</html>\n",
          "style.css": "body { background: #fff; }\n",
          "main.js": "console.log('hello');\n"
        }
      },
      {
        "input": {
          "test1.txt": "foo\nbar\nbaz\n",
          "test2.txt": "qux\nquux\nquuux\n"
        },
        "output": {
          "test1.txt": "foo\nbar\nbaz",
          "test2.txt": "qux\nquux\nquuux"
        }
      }
    ],
    "identifier": 33359437
  },
  {
    "context": [
      "Now I wish to replace the number \"3.0.7\" with \"3.0.6\" using shell tool `jq`.",
      "(.processes[] | select(.version == \"3.0.7\")).version = \"3.0.6\"",
      "$ cat automationConfig | jq '.processes[].version = \"3.0.6\"'"
    ],
    "utterance": "Replace all occurrences of the value \"3.0.7\" for the version field inside each processes element with \"3.0.6\".",
    "expressions": [
      "(.processes[] | select(.version == \"3.0.7\")).version = \"3.0.6\"",
      ".processes[].version = \"3.0.6\""
    ],
    "identifier": 33440952
  },
  {
    "context": [
      "Using [jq][1], how can arbitrary JSON encoding an array of shallow objects be converted to CSV?",
      "There are plenty of Q&As on this site that cover specific data models which hard-code the fields, but answers to this question should work given any JSON, with the only restriction that it's an array of objects with scalar properties (no deep/complex/sub-objects, as flattening these is another question). The result should contain a header row giving the field names.",
      "First, obtain an array containing all the different object property names in your object array input. Those will be the columns of your CSV:",
      "(map(keys) | add | unique) as $cols",
      "Then, for each object in the object array input, map the column names you obtained to the corresponding properties in the object. Those will be the rows of your CSV.",
      "Finally, put the column names before the rows, as a header for the CSV, and pass the resulting row stream to the `@csv` filter.",
      "jq -r '(map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.])) as $rows | $cols, $rows[] | @csv'",
      "jq -r '(.[0] | keys_unsorted) as $keys | $keys, map([.[ $keys[] ]])[] | @csv'",
      "jq -r '(map(keys)|add|unique)as$k|$k,(.[]|[.[$k[]]])|@csv'"
    ],
    "utterance": "Convert an array of shallow objects to CSV where the field names form the header row and all columns/fields are handled dynamically with no hard-coded keys.",
    "expressions": [
      "(map(keys) | add | unique) as $cols | map(. as $row | $cols | map($row[.])) as $rows | $cols, $rows[] | @csv",
      "(.[0] | keys_unsorted) as $keys | $keys, map([.[ $keys[] ]])[] | @csv",
      "(map(keys) | add | unique) as $k | $k, (.[] | [.[$k[]]]) | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "code": "NSW",
            "name": "New South Wales",
            "level": "state",
            "country": "AU"
          },
          {
            "code": "AB",
            "name": "Alberta",
            "level": "province",
            "country": "CA"
          },
          {
            "code": "ABD",
            "name": "Aberdeenshire",
            "level": "council area",
            "country": "GB"
          },
          {
            "code": "AK",
            "name": "Alaska",
            "level": "state",
            "country": "US"
          }
        ],
        "output": [
          "code,name,level,country",
          "NSW,New South Wales,state,AU",
          "AB,Alberta,province,CA",
          "ABD,Aberdeenshire,council area,GB",
          "AK,Alaska,state,US"
        ]
      },
      {
        "input": [
          {
            "name": "bang",
            "value": "!",
            "level": 0
          },
          {
            "name": "letters",
            "value": "a,b,c",
            "level": 0
          },
          {
            "name": "letters",
            "value": "x,y,z",
            "level": 1
          },
          {
            "name": "bang",
            "value": "\"!\"",
            "level": 1
          }
        ],
        "output": [
          "name,value,level",
          "bang,!,0",
          "letters,\"a,b,c\",0",
          "letters,\"x,y,z\",1",
          "bang,\"\"\"!\"\"\",1"
        ]
      }
    ],
    "identifier": 32960857
  },
  {
    "context": [
      "I want to be able to set each item in the rooms array to something like room1, room2, room3 etc. But also to keep it in one entry, so for example with the sample here it ends up 5 entries because there is 5 rooms and name for instance gets repeated 5 times because the way I have it set now. I think I need to map the rooms to something but not sure how to do that.",
      "Here is a solution which uses functions.\r\n\r\n    def common_columns:\r\n       \"phone_number\", \"city\", \"updated\", \"name\", \"address\", \"zip_code\", \"url\", \"last_visited\"\r\n    ;\r\n    def common:\r\n       .phone_number, .city, .updated, .name, .address, .zip_code, .url, .last_visited\r\n    ;\r\n    def room_columns(n):\r\n         range(n)\r\n       | (\r\n          \"available_\\(.)\", \"bathrooms_\\(.)\", \"suite_type_\\(.)\",\r\n          \"square_feet_start_\\(.)\", \"square_feet_end_\\(.)\", \"deposit_\\(.)\",\r\n          \"price_range_start_\\(.)\", \"price_range_end_\\(.)\"\r\n         )\r\n    ;\r\n    def rooms(n):\r\n         . as $r\r\n       | range(n)\r\n       | $r.rooms[.]\r\n       | (\r\n           .available, .bathrooms[0], .suite_type,\r\n           .square_feet[0,1], .deposit[0], .price_range[0,1]\r\n         )\r\n    ;\r\n\r\n      [ common_columns, room_columns(6) ]\r\n    , [ common,         rooms(6) ]\r\n    | @csv\r\n\r\nYou can change the `6` to however many sets of room columns you need."
    ],
    "utterance": "Produce a single entry with columns for each room's fields as room1, room2, room3, etc., instead of repeating the main fields for each room.",
    "expressions": [
      "def common_columns:\n   \"phone_number\", \"city\", \"updated\", \"name\", \"address\", \"zip_code\", \"url\", \"last_visited\"\n;\ndef common:\n   .phone_number, .city, .updated, .name, .address, .zip_code, .url, .last_visited\n;\ndef room_columns(n):\n     range(n)\n   | (\n      \"available_\\(.)\", \"bathrooms_\\(.)\", \"suite_type_\\(.)\",\n      \"square_feet_start_\\(.)\", \"square_feet_end_\\(.)\", \"deposit_\\(.)\",\n      \"price_range_start_\\(.)\", \"price_range_end_\\(.)\"\n     )\n;\ndef rooms(n):\n     . as $r\n   | range(n)\n   | $r.rooms[.]\n   | (\n       .available, .bathrooms[0], .suite_type,\n       .square_feet[0,1], .deposit[0], .price_range[0,1]\n     )\n;\n\n  [ common_columns, room_columns(6) ]\n, [ common,         rooms(6) ]\n| @csv"
    ],
    "data": [
      {
        "input": {
          "phone_number": "780-414-2085",
          "city": "Edmonton",
          "updated": "2015-10-19T00:03:10",
          "name": "Sir William Place ",
          "url": "http://www.bwalk.com/en-CA/Rent/Details/Alberta/Edmonton/Sir-William-Place",
          "last_visited": "2015-10-19T00:03:10",
          "rooms": [
            {
              "available": "Available",
              "bathrooms": [
                "1"
              ],
              "suite_type": "1 Bedroom",
              "square_feet": [
                "594",
                "649"
              ],
              "deposit": [
                "$499"
              ],
              "price_range": [
                "$1059",
                "$1209"
              ]
            },
            {
              "available": "Available",
              "bathrooms": [
                "1"
              ],
              "suite_type": "1 Bedroom + Den",
              "square_feet": [
                "771"
              ],
              "deposit": [
                "$499"
              ],
              "price_range": [
                "$1169",
                "$1249"
              ]
            },
            {
              "available": "Available",
              "bathrooms": [
                "1",
                "2"
              ],
              "suite_type": "2 Bedroom",
              "square_feet": [
                "894",
                "970"
              ],
              "deposit": [
                "$499"
              ],
              "price_range": [
                "$1344",
                "$1494"
              ]
            },
            {
              "available": "Available",
              "bathrooms": [
                "2"
              ],
              "deal": [
                "October FREE and $299 Security Deposit on 12 month leases "
              ],
              "suite_type": "2 Bedroom Bi-level",
              "square_feet": [
                "894"
              ],
              "deposit": [
                "$499"
              ],
              "price_range": [
                "$1344",
                "$1394"
              ]
            },
            {
              "available": "Waiting List",
              "bathrooms": [
                "1"
              ],
              "suite_type": "Bachelor",
              "square_feet": [
                "540"
              ],
              "deposit": [
                "$499"
              ],
              "price_range": [
                "$1004",
                "$1054"
              ]
            }
          ],
          "address": "8830-85 St., Edmonton, Alberta, T6C 3C3",
          "zip_code": "T6C 3C3"
        }
      }
    ],
    "identifier": 33265654
  },
  {
    "context": [
      "I want to be able to take the `id` field from `properties`, and assign it to the parent, so that the result is:",
      "The following adds the \"id\" property as requested:\r\n\r\n    .objects.delegaciones.geometries[] |= (.id = .properties.id)"
    ],
    "utterance": "Assign each geometry's id property from its properties.id field at the immediate geometry level.",
    "expressions": [
      ".objects.delegaciones.geometries[] |= (.id = .properties.id)"
    ],
    "data": [
      {
        "input": {
          "type": "Topology",
          "objects": {
            "delegaciones": {
              "geometries": [
                {
                  "properties": {
                    "name": "Tlalpan",
                    "municip": "012",
                    "id": "09012",
                    "state": "09"
                  }
                }
              ]
            }
          }
        },
        "output": {
          "type": "Topology",
          "objects": {
            "delegaciones": {
              "geometries": [
                {
                  "id": "09012",
                  "properties": {
                    "name": "Tlalpan",
                    "municip": "012",
                    "id": "09012",
                    "state": "09"
                  }
                }
              ]
            }
          }
        }
      }
    ],
    "identifier": 33525267
  },
  {
    "context": [
      "how can I transform:\r\n\r\n    { \"a\": {\"b\": 0}, \"c\": {\"d\": 1}}\r\n\r\ninto:\r\n\r\n    {\"b\": {\"a\": 0}, \"d\": {\"c\": 1}}\r\n\r\nwithout knowing the name of the keys in the source?",
      "def swapper:\r\n  . as $in\r\n  | reduce keys[] as $key\r\n      ( {}; . + ( $in[$key] as $o\r\n                  | ($o|keys[0]) as $innerkey\r\n                  | { ($innerkey): { ($key): $o[$innerkey] } } ) ) ;",
      "with_entries(.key as $parent\r\n  | (.value|keys[0]) as $child\r\n  | {\r\n        key: $child,\r\n        value: { ($parent): .value[$child] }\r\n    }\r\n)",
      "[\r\n  . as $d\r\n| keys[]\r\n| $d[.] as $v\r\n| ($v|keys[]) as $vkeys\r\n| {\r\n    ($vkeys): {\r\n       (.): ($vkeys|$v[.])\r\n    }\r\n  }\r\n] | add"
    ],
    "utterance": "Swap the outer and inner keys in each nested object, so that each former inner key becomes the outer key with its value being an object whose key is the former outer key and its value is the former inner value.",
    "expressions": [
      "def swapper: . as $in | reduce keys[] as $key ( {}; . + ( $in[$key] as $o | ($o|keys[0]) as $innerkey | { ($innerkey): { ($key): $o[$innerkey] } } ) );",
      "with_entries(.key as $parent | (.value|keys[0]) as $child | { key: $child, value: { ($parent): .value[$child] } })",
      "[ . as $d | keys[] | $d[.] as $v | ($v|keys[]) as $vkeys | { ($vkeys): { (.): ($vkeys|$v[.]) } } ] | add"
    ],
    "data": [
      {
        "input": {
          "a": {
            "b": 0
          },
          "c": {
            "d": 1
          }
        },
        "output": {
          "b": {
            "a": 0
          },
          "d": {
            "c": 1
          }
        }
      }
    ],
    "identifier": 33520220
  },
  {
    "context": [
      "Could anybody help write a jq or python script which, for every block, would alter the \"metatag.eprints.citation\" so that all text after the date is deleted?",
      "`jq &#39;.[&quot;metatag.eprints.citation&quot;] |= match(&quot;.*?\\\\\\)&quot;).string // .&#39;`\r\n\r\nNeeds jq 1.5. What this does is set the value of `metatag.eprints.citation` to the result of matching itself to the regex `.*?\\)`, which will match everything before the first closing parenthesis. If there was no closing parenthesis for whatever reason, we use the alternative operator `//` to set the value back to whatever it was."
    ],
    "utterance": "For every object, remove all text in the 'metatag.eprints.citation' field after the first closing parenthesis, retaining up to and including that parenthesis.",
    "expressions": [
      ".[\"metatag.eprints.citation\"] |= match(\".*?\\\\)\").string // ."
    ],
    "data": [
      {
        "input": {
          "url": "http://example.com/10618/",
          "metatag.eprints.publication": "Journal of Corporate Real Estate",
          "metatag.eprints.title": "Corporate Real Estate Strategy",
          "metatag.eprints.citation": "Adair, P, McGrogan, WS, and Webb, JR (2006) Corporate Real Estate Strategy. Journal of Corporate Real Estate"
        },
        "output": {
          "url": "http://example.com/10618/",
          "metatag.eprints.publication": "Journal of Corporate Real Estate",
          "metatag.eprints.title": "Corporate Real Estate Strategy",
          "metatag.eprints.citation": "Adair, P, McGrogan, WS, and Webb, JR (2006)"
        }
      },
      {
        "input": {
          "url": "http://example.com/23552/",
          "metatag.eprints.publication": "European Journal of Cardio-Thoracic Surgery",
          "metatag.eprints.title": "Long-term survival from coronary endarterectomies in coronary artery disease",
          "metatag.eprints.citation": "Aaron, P, Jones, K, Pallin, C, and Nash, R (2012) Long-term survival from coronary endarterectomies in coronary artery disease. European Journal of Cardio-Thoracic Surgery"
        },
        "output": {
          "url": "http://example.com/23552/",
          "metatag.eprints.publication": "European Journal of Cardio-Thoracic Surgery",
          "metatag.eprints.title": "Long-term survival from coronary endarterectomies in coronary artery disease",
          "metatag.eprints.citation": "Aaron, P, Jones, K, Pallin, C, and Nash, R (2012)"
        }
      }
    ],
    "identifier": 33107524
  },
  {
    "context": [
      "jq --arg mod \"acme\" \\\n   --arg resolved \"some_url\" \\\n  '.dependencies[$mod].resolved=$resolved' \\\n  <in.json >out.json",
      "jq --arg new_url \"http://new.url/\" \\\n   --arg target \"acme@1.2.3\" \\\n  '.dependencies=(.dependencies\n                  | to_entries\n                  | map(if(.value.from == $target)\n                        then .value.resolved=$new_url\n                        else . end)\n                  | from_entries)' \\\n  <in.json >out.json",
      "$ jq --arg dep \"$dep\" --arg resolved \"$resolved\" \\\n    '.dependencies[$dep].resolved = $resolved' \\\n    OLD.json > NEW.json",
      "$ jq --arg version \"$version\" --arg resolved \"$resolved\" \\\n    '(.dependencies[] | select(.version == $version)).resolved = $resolved' \\\n    OLD.json > NEW.json"
    ],
    "utterance": "Update the 'resolved' field of a dependency object nested under 'dependencies', where the dependency is identified by its name or where a property such as 'from' or 'version' matches a specific value.",
    "expressions": [
      ".dependencies[$mod].resolved=$resolved",
      ".dependencies=(.dependencies | to_entries | map(if(.value.from == $target) then .value.resolved=$new_url else . end) | from_entries)",
      ".dependencies[$dep].resolved = $resolved",
      "(.dependencies[] | select(.version == $version)).resolved = $resolved"
    ],
    "data": [
      {
        "input": {
          "name": "vendor-module",
          "dependencies": {
            "abc": {
              "from": "abc@2.4.0",
              "resolved": "https://some.special.url",
              "version": "2.4.0"
            },
            "acme": {
              "from": "acme@1.2.3",
              "resolved": "<CHANGE_THIS>",
              "version": "1.2.3"
            }
          }
        },
        "output": {
          "name": "vendor-module",
          "dependencies": {
            "abc": {
              "from": "abc@2.4.0",
              "resolved": "https://some.special.url",
              "version": "2.4.0"
            },
            "acme": {
              "from": "acme@1.2.3",
              "resolved": "some_url",
              "version": "1.2.3"
            }
          }
        }
      }
    ],
    "identifier": 33554246
  },
  {
    "context": [
      "I want to iterate over this json file",
      "I am getting count and name properly but not able to fetch version information. How can I get it.",
      "You might find it easier to turn your object's fields into an array using jq's to_entries ...",
      "to_entries | .[0].key",
      "to_entries | .[0].value.version",
      "jq -r 'to_entries[] | \"\\(.key)\\t\\(.value.version)\"' input.json |",
      "name: atest_engine",
      "version: 96"
    ],
    "utterance": "For each top-level key, retrieve both the key name and its associated value's version property.",
    "expressions": [
      "to_entries[] | \"\\(.key)\\t\\(.value.version)\""
    ],
    "data": [
      {
        "input": {
          "atest_engine": {
            "version": "96"
          },
          "a_kdfvm": {
            "version": "68"
          },
          "aseft_api": {
            "version": ""
          },
          "push_psservice": {
            "version": "68"
          }
        },
        "output": [
          "atest_engine\t96",
          "a_kdfvm\t68",
          "aseft_api\t",
          "push_psservice\t68"
        ]
      }
    ],
    "identifier": 33622925
  },
  {
    "context": [
      "I want something like:\n\n    {\n      \"d\": [ \n        \"a\",\n        \"b\"\n      ],\n      \"c\": [\n        \"e\"\n      ]\n    }",
      "I can get the list of keys on the first level under \"p\" with `jq '.p|keys'`, and the structure and keys on the second level with `jq '.p|map(.|keys)'`, but I can't figure out how to combine it.",
      "Use `map_values` instead of `map` to map the values of a JSON object while preserving the keys:",
      "jq '.p | map_values(keys)'",
      "On jq versions lower than 1.5, `map_values` is not defined: instead, you can use `[]|=`:",
      "jq '.p | . []|= keys'"
    ],
    "utterance": "Retrieve an object mapping each top-level key under 'p' to a list of its subkeys.",
    "expressions": [
      ".p | map_values(keys)",
      ".p | .[] |= keys"
    ],
    "data": [
      {
        "input": {
          "p": {
            "d": {
              "a": {
                "r": "foo",
                "g": 1
              },
              "b": {
                "r": "bar",
                "g": 2
              }
            },
            "c": {
              "e": {
                "r": "baz",
                "g": 1
              }
            }
          }
        },
        "output": {
          "d": [
            "a",
            "b"
          ],
          "c": [
            "e"
          ]
        }
      }
    ],
    "identifier": 33627427
  },
  {
    "context": [
      "I want convert it using JQ, unrolling the list to a fixed number of \"columns\", ending up with a list of flat JSON objects, with the following format:",
      "{ \"top-level-key\": .toplevel_key } + ([\n    range(.list|length) as $i\n        | .list[$i]\n        | to_entries[]\n        | .key = \"list_\\($i)_\\(.key)\"\n    ] | from_entries)",
      "If you need to pad it out, you'll have to slurp up the results to determine how much is actually needed and add the padding.",
      "However, your original question requested values appearing on any of the input objects to appear in all of the outputs, with the corresponding values set to empty strings when missing on the input. Here's a jq program that does this: as Jeff says in his answer, you need to slurp (`-s`) all the input values for it to be possible:\n\n    (map(leaf_paths) | unique) as $paths |\n    map([$paths[] as $path | {\n        \"key\": $path | map(tostring) | join(\"_\"),\n        \"value\": (getpath($path) // \"\")\n    }] | from_entries)[]"
    ],
    "utterance": "Unroll each object's list into flat fields with indexed keys, and for each possible field ensure all output objects have those keys, padding with empty strings where data is missing.",
    "expressions": [
      "{ \"top-level-key\": .toplevel_key } + ([range(.list|length) as $i | .list[$i] | to_entries[] | .key = \"list_\\($i)_\\(.key)\"] | from_entries)",
      "(map(leaf_paths) | unique) as $paths | map([$paths[] as $path | {\"key\": $path | map(tostring) | join(\"_\"), \"value\": (getpath($path) // \"\")}] | from_entries)[]"
    ],
    "data": [
      {
        "input": [
          {
            "toplevel_key": "top value 1",
            "list": [
              {
                "key1": "value 1",
                "key2": "value 2"
              },
              {
                "key1": "value 3",
                "key2": "value 4"
              }
            ]
          },
          {
            "toplevel_key": "top value 2",
            "list": [
              {
                "key1": "value 5",
                "key2": "value 6"
              }
            ]
          }
        ],
        "output": [
          {
            "top-level-key": "top value 1",
            "list_0_key1": "value 1",
            "list_0_key2": "value 2",
            "list_1_key1": "value 3",
            "list_1_key2": "value 4"
          },
          {
            "top-level-key": "top value 2",
            "list_0_key1": "value 5",
            "list_0_key2": "value 6",
            "list_1_key1": "",
            "list_1_key2": ""
          }
        ]
      }
    ],
    "identifier": 33286778
  },
  {
    "context": [
      "what I really need to get is the `\"External IPs\"` value and I can't figure out how to manage the space.",
      "Use quoting as in:",
      "jq --raw-output '.gateways[0].\"External IPs\"'"
    ],
    "utterance": "Extract the value of the 'External IPs' key from the first element of the gateways array.",
    "expressions": [
      ".gateways[0].\"External IPs\""
    ],
    "data": [
      {
        "input": {
          "gateways": [
            {
              "DHCP": "On",
              "External IPs": "46.244.46.66",
              "Firewall": "On",
              "NAT": "Off",
              "Name": "gateway",
              "Routed Networks": "photon, default-routed-network",
              "Selected": "*",
              "Syslog": "",
              "Uplinks": "d5p6v51-ext",
              "VPN": "Off"
            }
          ]
        },
        "output": "46.244.46.66"
      }
    ],
    "identifier": 33700103
  },
  {
    "context": [
      "I don't understand why key has to be in `()` for this to work:",
      "$ cat host | jq '. | to_entries | map({ (.key) : .value.CPU.PercentUsed })' | tail",
      "$ cat host | jq '. | to_entries | map({ .key : .value.CPU.PercentUsed })' | tail",
      "jq: error: syntax error, unexpected FIELD (Unix shell quoting issues?) at <top-level>, line 1:",
      "When defining an object literal, the parentheses indicates that the expression value should be the property name.  Otherwise if you didn't use parentheses, it's the literal name.",
      "{ foo: 1 }",
      "{ \"foo\": 2 }",
      "\"foo\" as $name | { ($name): 3 }",
      "{ somename: \"foo\" } | { (.somename): 4 }"
    ],
    "utterance": "Transform each entry to an object where the key is dynamically set to the value of .key and the value is .value.CPU.PercentUsed",
    "expressions": [
      ". | to_entries | map({ (.key) : .value.CPU.PercentUsed })"
    ],
    "identifier": 33700997
  },
  {
    "context": [
      "How can I recursive find all arrays in object and reduce them to first item ?",
      "Here&#39;s how it can be used to achieve your objective as I understand it:\r\n\r\n    walk(if type == &quot;array&quot; and length &gt; 1 then [.[0]] else . end)",
      "The na&#239;ve solution I came up with was `(.. | arrays) |= .[0]`, but that doesn&#39;t work because the recursion is done from the outside, which means that on nested cases we end up trying to get .[0] from values who are no longer arrays.",
      "With `post_recurse`, it&#39;s just a matter of replacing `..` with `post_recurse` in the na&#239;ve solution above. The full solution:\r\n\r\n    def post_recurse(f): def r: (f | select(. != null) | r), .; r; def post_recurse: post_recurse(.[]?); (post_recurse | arrays) |= .[0]",
      "Here is a solution using **tostream** which converts the input object\r\ninto a stream of paths, filters out any paths with nonzero array indices\r\nand converts the result back to an object using **reduce** and **setpath**.   All the recursion is internal to **tostream**.",
      "input:\r\n\r\n    {\r\n      \"a\": 1,\r\n      \"b\": [\r\n        1,\r\n        2,\r\n        3\r\n      ],\r\n      \"c\": [\r\n        {\r\n          \"a\": 1,\r\n          \"b\": [\r\n            1,\r\n            2,\r\n            3\r\n          ],\r\n          \"c\": {\r\n            \"a\": 1,\r\n            \"b\": [\r\n              1,\r\n              2,\r\n              3\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          \"a\": 1,\r\n          \"b\": [\r\n            1,\r\n            2,\r\n            3\r\n          ],\r\n          \"c\": {\r\n            \"a\": 1,\r\n            \"b\": [\r\n              1,\r\n              2,\r\n              3\r\n            ]\r\n          }\r\n        },\r\n        {\r\n          \"a\": 1,\r\n          \"b\": [\r\n            1,\r\n            2,\r\n            3\r\n          ],\r\n          \"c\": {\r\n            \"a\": 1,\r\n            \"b\": [\r\n              1,\r\n              2,\r\n              3\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }\r\n\r\noutput: \r\n\r\n    {\r\n      \"a\": 1,\r\n      \"b\": [\r\n        1\r\n      ],\r\n      \"c\": [\r\n        {\r\n          \"a\": 1,\r\n          \"b\": [\r\n            1\r\n          ],\r\n          \"c\": {\r\n            \"a\": 1,\r\n            \"b\": [\r\n              1\r\n            ]\r\n          }\r\n        }\r\n      ]\r\n    }"
    ],
    "utterance": "Reduce every array at any level of the object so that it contains only its first element.",
    "expressions": [
      "walk(if type == \"array\" and length > 1 then [.[0]] else . end)",
      "def post_recurse(f): def r: (f | select(. != null) | r), .; r; def post_recurse: post_recurse(.[]?); (post_recurse | arrays) |= .[0]",
      "[ tostream\n| if   length != 2 then empty\n  elif ([.[0][]|numbers|.!=0]|any) then empty\n  else .\n  end\n]\n| reduce .[] as $p (\n    {};     \n    setpath($p[0]; $p[1])\n)"
    ],
    "data": [
      {
        "input": {
          "a": 1,
          "b": [
            1,
            2,
            3
          ],
          "c": [
            {
              "a": 1,
              "b": [
                1,
                2,
                3
              ],
              "c": {
                "a": 1,
                "b": [
                  1,
                  2,
                  3
                ]
              }
            },
            {
              "a": 1,
              "b": [
                1,
                2,
                3
              ],
              "c": {
                "a": 1,
                "b": [
                  1,
                  2,
                  3
                ]
              }
            },
            {
              "a": 1,
              "b": [
                1,
                2,
                3
              ],
              "c": {
                "a": 1,
                "b": [
                  1,
                  2,
                  3
                ]
              }
            }
          ]
        },
        "output": {
          "a": 1,
          "b": [
            1
          ],
          "c": [
            {
              "a": 1,
              "b": [
                1
              ],
              "c": {
                "a": 1,
                "b": [
                  1
                ]
              }
            }
          ]
        }
      }
    ],
    "identifier": 33558674
  },
  {
    "context": [
      "I am trying to use jq 1.5 to develop a script that can take one or more user inputs that represent a key and recursively remove them from JSON input.",
      "However, I would like to replace META_BASIC_INFO with one or more user inputs. How would I go about accomplishing this? I presume with --arg from the command line, but I am unclear on how to incorporate this into my .jq script?",
      "Innvocation:\n\n    cat test.json | jq --argjson delete '[\"META_BASIC_INFO\",\"SCAN_YARA\"]' -f fsf_module_filter.jq",
      "Code:\n\n    def post_recurse(f):\n            def r:\n                    (f | select(. != null) | r), .;\n                    r;\n    def post_recurse:\n            post_recurse(.[]?);\n    (post_recurse | objects) |= reduce $delete[] as $d (.; delpaths([[ $d ]]))",
      "You could also use delpaths/1.  For example:\n\n    $ jq -n '{\"a\":1, \"b\": 1} | delpaths([[\"a\"]])'\n    {\n      \"b\": 1\n    }\n\nThat is, modifying your program so that the last line reads like this:\n\n    (post_recurse | objects) |= delpaths([[ $delete ]] )",
      "you would invoke jq like so:\n\n    $ jq --arg delete \"META_BASIC_INFO\" -f delete.jq input.json",
      "If you want to recursively delete a bunch of key-value pairs, then here's one approach using `--argjson`:\n\nrdelete.jq:\n\ndef rdelete(key):\n  walk(if type == \"object\" then del(.[key]) else . end);\n\nreduce $strings[] as $s (.; rdelete($s))\n\nInvocation:\n\n    $ jq --argjson strings '[\"a\",\"b\"]' -f rdelete.jq input.json"
    ],
    "utterance": "Recursively remove all objects with any of a user-specified list of keys from deeply nested data, with keys provided at invocation time.",
    "expressions": [
      "def post_recurse(f):\n    def r:\n        (f | select(. != null) | r), .;\n        r;\ndef post_recurse:\n    post_recurse(.[]?);\n(post_recurse | objects) |= reduce $delete[] as $d (.; delpaths([[ $d ]]))",
      "def post_recurse(f):\n    def r:\n        (f | select(. != null) | r), .;\n        r;\ndef post_recurse:\n    post_recurse(.[]?);\n(post_recurse | objects) |= delpaths([[ $delete ]])",
      "def rdelete(key):\n  walk(if type == \"object\" then del(.[key]) else . end);\n\nreduce $strings[] as $s (.; rdelete($s))"
    ],
    "identifier": 33656260
  },
  {
    "context": [
      "should add new nested objects under each top-level key with the name of its <unknown> top-level key. So the result looks like\n\n    {\n        \"key x\": {\n            \"a\": \"key x\",\n            \"b\": \"1\"\n        },\n        \"key y\": {\n            \"a\": \"key y\",\n            \"b\": \"1\"\n        }\n    }",
      "But without using the key names (e.g. .\"key x\".a=\"key x\") directly, because i dont know during runtime the real key names.",
      "with_entries(.value.a = .key)",
      "to_entries  | map( {(.key): ({a: .key}+.value)} ) | add"
    ],
    "utterance": "Add a field 'a' to each top-level object, setting its value to the corresponding top-level key name, without knowing those keys in advance.",
    "expressions": [
      "with_entries(.value.a = .key)",
      "to_entries | map({(.key): ({a: .key} + .value)}) | add"
    ],
    "data": [
      {
        "input": {
          "key x": {
            "b": "1"
          },
          "key y": {
            "b": "1"
          }
        },
        "output": {
          "key x": {
            "a": "key x",
            "b": "1"
          },
          "key y": {
            "a": "key y",
            "b": "1"
          }
        }
      }
    ],
    "identifier": 33707655
  },
  {
    "context": [
      "my jq file was in UTF-8, if i change it to ansi it works!",
      "prepare a couple of files, `id.jq` with sane Unix line endings and `id-ms.jq` with Microsoft's CP/M style CR-LF line endings, and finally `id-utf8bom.jq` with a Unix line endings and a UTF-8 BOM:",
      "and the Unix version succeeds:\n\necho true | jq -f id.jq",
      "while the file with carriage return and line feeds for new lines:\n\necho true | jq -f id-ms.jq\ncauses jq (version 1.6) to fail with:\n\njq: error: syntax error, unexpected INVALID_CHARACTER (Unix shell quoting issues?)",
      "and the version with a UTF-8 BOM version:\n\necho true | jq -f id-utf8bom.jq\ngives a more limited error message:\n\njq: error: syntax error, unexpected INVALID_CHARACTER, expecting $end"
    ],
    "utterance": "Process input using a file containing only '.' as the filter, where the file uses Unix line endings and no BOM or special encoding.",
    "expressions": [
      "jq -f id.jq"
    ],
    "data": [
      {
        "input": true,
        "output": true
      }
    ],
    "identifier": 33722144
  },
  {
    "context": [
      "What I want to do is have an If then else for the Partner_attributions field that if there is something there make it a yes and if it is null make it No.",
      "You need to create an actual object to add to the first object.  Change the `if` expression to:\n\n    {partner_attributions: (if (.partner_attributions | length) > 0 then \"yes\" else \"no\" end)}",
      "Better yet perhaps:\n\n    .partner_attributions |= (if length > 0 then \"yes\" else \"no\" end)\n\nThis just updates the one field without modifying anything else."
    ],
    "utterance": "Set partner_attributions to \"yes\" if the field is non-empty, otherwise set it to \"no\".",
    "expressions": [
      "{partner_attributions: (if (.partner_attributions | length) > 0 then \"yes\" else \"no\" end)}",
      ".partner_attributions |= (if length > 0 then \"yes\" else \"no\" end)"
    ],
    "data": [
      {
        "input": {
          "_key": "USCA3DC_8f4521822c099c3e",
          "partner_attributions": [
            "This business is a Yelp advertiser."
          ],
          "showcase_photos": [
            [
              "Mathnasium of Westwood - Westwood, CA, United States. Nice and       caring instructors",
              "http://s3-media1.fl.yelpcdn.com/bphoto/KeKAhvy2HHY4KGpvA24VaA/ls.jpg"
            ],
            [
              "Mathnasium of Westwood - Westwood, CA, United States. Prize box and estimation jar!",
              "http://s3-media3.fl.yelpcdn.com/bphoto/lJWHHCAVaUMfeFD7GDKtHw/ls.jpg"
            ],
            [
              "Mathnasium of Westwood - Westwood, CA, United States. New table setup!!!!",
              "http://s3-media2.fl.yelpcdn.com/bphoto/kVYJrYqDRHPOH4F2uTuFVg/ls.jpg"
            ],
            [
              "Mathnasium of Westwood - Westwood, CA, United States. Halloween party",
              "http://s3-media3.fl.yelpcdn.com/bphoto/wKm5KjF0V8MsPTVSuofPEQ/180s.jpg"
            ],
            [
              "Mathnasium of Westwood - Westwood, CA, United States",
              "http://s3-media4.fl.yelpcdn.com/bphoto/r2981msJm0c1ocU09blb1A/180s.jpg"
            ],
            [
              "Mathnasium of Westwood - Westwood, CA, United States",
              "http://s3-media3.fl.yelpcdn.com/bphoto/r2Vgo18YKeUojDvjQMRF_A/180s.jpg"
            ]
          ],
          "review_count": "24",
          "yelp_id": "t7WyXcABE3xj20G-UqXalA",
          "rating_value": "5.0",
          "coordinates": {
            "latitude": "34.042568",
            "longitude": "-118.431038"
          }
        },
        "output": {
          "_key": "USCA3DC_8f4521822c099c3e",
          "partner_attributions": "yes",
          "showcase_photos": [
            [
              "Mathnasium of Westwood - Westwood, CA, United States. Nice and       caring instructors",
              "http://s3-media1.fl.yelpcdn.com/bphoto/KeKAhvy2HHY4KGpvA24VaA/ls.jpg"
            ],
            [
              "Mathnasium of Westwood - Westwood, CA, United States. Prize box and estimation jar!",
              "http://s3-media3.fl.yelpcdn.com/bphoto/lJWHHCAVaUMfeFD7GDKtHw/ls.jpg"
            ],
            [
              "Mathnasium of Westwood - Westwood, CA, United States. New table setup!!!!",
              "http://s3-media2.fl.yelpcdn.com/bphoto/kVYJrYqDRHPOH4F2uTuFVg/ls.jpg"
            ],
            [
              "Mathnasium of Westwood - Westwood, CA, United States. Halloween party",
              "http://s3-media3.fl.yelpcdn.com/bphoto/wKm5KjF0V8MsPTVSuofPEQ/180s.jpg"
            ],
            [
              "Mathnasium of Westwood - Westwood, CA, United States",
              "http://s3-media4.fl.yelpcdn.com/bphoto/r2981msJm0c1ocU09blb1A/180s.jpg"
            ],
            [
              "Mathnasium of Westwood - Westwood, CA, United States",
              "http://s3-media3.fl.yelpcdn.com/bphoto/r2Vgo18YKeUojDvjQMRF_A/180s.jpg"
            ]
          ],
          "review_count": "24",
          "yelp_id": "t7WyXcABE3xj20G-UqXalA",
          "rating_value": "5.0",
          "coordinates": {
            "latitude": "34.042568",
            "longitude": "-118.431038"
          }
        }
      },
      {
        "input": {
          "_key": "ExampleKey",
          "partner_attributions": [],
          "showcase_photos": [],
          "review_count": "0",
          "yelp_id": "exampleid",
          "rating_value": "0.0",
          "coordinates": {
            "latitude": "0.000000",
            "longitude": "0.000000"
          }
        },
        "output": {
          "_key": "ExampleKey",
          "partner_attributions": "no",
          "showcase_photos": [],
          "review_count": "0",
          "yelp_id": "exampleid",
          "rating_value": "0.0",
          "coordinates": {
            "latitude": "0.000000",
            "longitude": "0.000000"
          }
        }
      }
    ],
    "identifier": 33572755
  },
  {
    "context": [
      "I would like to exclude all keys with the name \"key_x\" so the result should be ...",
      "You can use the [`del()`][1] function:\r\n\r\n    jq 'del(.[]|.key_x)' input.json"
    ],
    "utterance": "Remove all embedded keys named \"key_x\" from all first-level objects in the input.",
    "expressions": [
      "del(.[]|.key_x)"
    ],
    "data": [
      {
        "input": {
          "key1": {
            "key_x": "1",
            "foo": "abc",
            "key_z": "2"
          },
          "key2": {
            "key_x": "2",
            "bar": "def",
            "key_z": "3"
          }
        },
        "output": {
          "key1": {
            "foo": "abc",
            "key_z": "2"
          },
          "key2": {
            "bar": "def",
            "key_z": "3"
          }
        }
      }
    ],
    "identifier": 33827226
  },
  {
    "context": [
      "I will like to get the same structure without the ones that `countries` hasn't \"de\" (Germany) and remove the field complete. Expected something like this:\n\n    [\n      {\n        \"stock\": 1,\n        \"sizes\": [\n          {\n            \"size\": \"EU 45,5\"\n          }\n        ]\n      }\n    ]",
      "Here's a one-liner that answers your main question -- if you can't see how it works, try breaking it up into separate pieces:\n\n    map( .sizes |= map( select(.countries | index(\"de\") ) | del(.countries) ))"
    ],
    "utterance": "Filter the list so that only size objects with \"countries\" containing \"de\" are kept, and remove the \"countries\" field from the result.",
    "expressions": [
      "map( .sizes |= map( select(.countries | index(\"de\") ) | del(.countries) ))"
    ],
    "data": [
      {
        "input": [
          {
            "stock": 1,
            "sales": 0,
            "sizes": [
              {
                "countries": [
                  "at",
                  "be",
                  "ch",
                  "cy",
                  "de",
                  "ee",
                  "es",
                  "fi",
                  "gr",
                  "ie",
                  "lu",
                  "lv",
                  "nl",
                  "pl",
                  "pt",
                  "se",
                  "si",
                  "sk"
                ],
                "size": "EU 45,5"
              },
              {
                "countries": [
                  "it"
                ],
                "size": "EU 45,5"
              },
              {
                "countries": [
                  "fr"
                ],
                "size": "EU 45,5"
              },
              {
                "countries": [
                  "gb"
                ],
                "size": "EU 45,5"
              }
            ]
          }
        ],
        "output": [
          {
            "stock": 1,
            "sizes": [
              {
                "size": "EU 45,5"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 33784931
  },
  {
    "context": [
      "Now I have to concatenate all .name elements for each item of the array.",
      "Sometimes .name can be empty, not null, nothing just empty. So I do need a // \"null\" added to the filter as well.",
      "Does this solve your problem?",
      ".cars | map(.name? // empty) | join(\",\")"
    ],
    "utterance": "For each array in 'cars', concatenate the 'name' values of each item, handling cases where 'name' may be empty.",
    "expressions": [
      ".cars | map(.name? // empty) | join(\",\")"
    ],
    "data": [
      {
        "input": [
          [
            {
              "self": "link",
              "id": "18900",
              "name": "Audi",
              "releaseDate": "2015-12-11"
            }
          ],
          [
            {
              "self": "link",
              "id": "18900",
              "name": "VW",
              "releaseDate": "2015-12-11"
            }
          ],
          [
            {
              "self": "link",
              "id": "19400",
              "name": "Audi",
              "releaseDate": "2015-11-20"
            },
            {
              "self": "link",
              "id": "18900",
              "name": "Honda",
              "releaseDate": "2015-12-11"
            },
            {
              "self": "link",
              "id": "19201",
              "name": "Chevy",
              "releaseDate": "2016-01-08"
            }
          ]
        ],
        "output": [
          "Audi",
          "VW",
          "Audi,Honda,Chevy"
        ]
      }
    ],
    "identifier": 33805577
  },
  {
    "context": [
      "jq -s '.'' *.json > output.json",
      "returns an error that the file list is too long. Is there a way to write this that uses a method that will take in more files?",
      "for f in *.json; do\n    cat \"$f\"\ndone | jq -s '.' > output.json",
      "find . -name '*.json' -exec cat '{}' + | jq -s '.' > output.json",
      "find . -name '*.json' -exec jq -s '{}' + > output.json",
      "$ zargs *.json -- cat | jq -s . > output.json",
      "$ find -maxdepth 1 -name \\*.json -exec cat {} + | jq -s . > output.json"
    ],
    "utterance": "Combine the contents of hundreds of thousands of .json files in a directory into a single array, avoiding argument list too long errors.",
    "expressions": [
      "for f in *.json; do cat \"$f\"; done | jq -s '.' > output.json",
      "find . -name '*.json' -exec cat '{}' + | jq -s '.' > output.json",
      "$ zargs *.json -- cat | jq -s . > output.json",
      "find -maxdepth 1 -name '*.json' -exec cat {} + | jq -s . > output.json"
    ],
    "identifier": 33883060
  },
  {
    "context": [
      "Can jq efficiently take data like this:\n\n    file1:\n    id,age,gender,wave\n    1,49,M,1\n    2,72,F,0\n\n    file2:\n    id,time,event1\n    1,4/20/2095,V39\n    1,4/21/2095,T21\n    2,5/17/2094,V39\n\naggregate it by id (such that all the JSON documents from CSV rows in multiple files fall under a single id entry), outputting something like this:\n\n    {\"index\":{\"_index\":\"forum_mat\",\"_type\":\"subject\",\"_id\":\"1\"}}\n    {\"id\":\"1\",\"file1\":[{\"filen\":\"file1\",\"id\":\"1\",\"age\":\"49\",\"gender\":\"M\",\"wave\":\"1\"}],\"file2\":[{\"filen\":\"file2\",\"id\":\"1\",\"time\":\"4/20/2095\",\"event1\":\"V39\"},{\"filen\":\"file2\",\"id\":\"1\",\"time\":\"4/21/2095\",\"event1\":\"T21\"}]}\n    {\"index\":{\"_index\":\"forum_mat\",\"_type\":\"subject\",\"_id\":\"2\"}}\n    {\"id\":\"2\",\"file1\":[{\"filen\":\"file1\",\"id\":\"2\",\"age\":\"72\",\"gender\":\"F\",\"wave\":\"0\"}],\"file2\":[{\"filen\":\"file2\",\"id\":\"2\",\"time\":\"5/17/2094\",\"event1\":\"V39\"}]}",
      "The program assumes all your data will fit into memory.  It uses JSON objects as dictionaries for fast lookup and so should be quite performant.\n\nThe approach taken here separates the csv-to-json conversion from the aggregation, as there may be better ways to do the former.  (See for example [the jq Cookbook entry on convert-a-csv-file-with-headers-to-json][1].)\n\nThe first file (scsv2json.jq) is for converting simple CSV to JSON.  The second file (aggregate.jq) does the aggregation.  With these in place:\n\n```\n$ (jq -R -s -f scsv2json.jq file1.csv ;\\\n   jq -R -s -f scsv2json.jq file2.csv) |\\\n   jq -s -c -f aggregate.jq\n[{\"id\":\"1\",\n  \"file1\":{\"age\":\"49\",\"gender\":\"M\",\"wave\":\"1\"},\n  \"file2\":{\"time\":\"4/21/2095\",\"event1\":\"T21\"}},\n {\"id\":\"2\",\n   \"file1\":{\"age\":\"72\",\"gender\":\"F\",\"wave\":\"0\"},\n   \"file2\":{\"time\":\"5/17/2094\",\"event1\":\"V39\"}}]\n``` \n\nNotice that the \"id\" has been removed from the inner objects in the output.",
      "def todictionary:\n  reduce .[] as $row ( {}; . + { ($row.id | tostring): $row } );\n\ndef aggregate:\n  .[0] as $file1\n  | .[1] as $file2\n  | ($file1 | todictionary) as $d1\n  | ($file2 | todictionary) as $d2\n  | ( [$file1[].id] + [$file2[].id] | unique ) as $keys\n  | reduce ($keys[] | tostring) as $k\n      ( [];\n        . + [{\"id\": $k, \n              \"file1\": ($d1[$k] | del(.id)),\n              \"file2\": ($d2[$k] | del(.id)) }] );\n\naggregate"
    ],
    "utterance": "Group rows from multiple CSV sources by id so each id has its own entry containing data from all files.",
    "expressions": [
      "def todictionary:\n  reduce .[] as $row ( {}; . + { ($row.id | tostring): $row } );\n\ndef aggregate:\n  .[0] as $file1\n  | .[1] as $file2\n  | ($file1 | todictionary) as $d1\n  | ($file2 | todictionary) as $d2\n  | ( [$file1[].id] + [$file2[].id] | unique ) as $keys\n  | reduce ($keys[] | tostring) as $k\n      ( [];\n        . + [{\"id\": $k, \n              \"file1\": ($d1[$k] | del(.id)),\n              \"file2\": ($d2[$k] | del(.id)) }] );\n\naggregate"
    ],
    "data": [
      {
        "input": [
          [
            {
              "id": "1",
              "age": "49",
              "gender": "M",
              "wave": "1"
            },
            {
              "id": "2",
              "age": "72",
              "gender": "F",
              "wave": "0"
            }
          ],
          [
            {
              "id": "1",
              "time": "4/20/2095",
              "event1": "V39"
            },
            {
              "id": "1",
              "time": "4/21/2095",
              "event1": "T21"
            },
            {
              "id": "2",
              "time": "5/17/2094",
              "event1": "V39"
            }
          ]
        ],
        "output": [
          {
            "id": "1",
            "file1": {
              "age": "49",
              "gender": "M",
              "wave": "1"
            },
            "file2": {
              "time": "4/21/2095",
              "event1": "T21"
            }
          },
          {
            "id": "2",
            "file1": {
              "age": "72",
              "gender": "F",
              "wave": "0"
            },
            "file2": {
              "time": "5/17/2094",
              "event1": "V39"
            }
          }
        ]
      }
    ],
    "identifier": 33535186
  },
  {
    "context": [
      "Ultimately what I would really like is a list with unique values like this:\n\n    employees,elgalu\n    employees,mike\n    services,pacts",
      "Since you know which fields should appear in output, you can simply populate an array with `group` and `id` and then use the `join()` function:\n\n    jq -r '.[]|[.group,.uid]|join(\",\")' input.json",
      "For the record, an alternative would be:\n\n    $ jq -r '.[] | \"\\(.uid),\\(.group)\"' input.json",
      "The following example may be of interest to anyone who wants safe CSV (i.e. even if the values have embedded commas or newline characters):\n\n    $ jq -r '.[] | [.uid, .group] | @csv' input.json\n    \"elgalu\",\"employees\"\n    \"mike\",\"employees\"\n    \"pacts\",\"services\""
    ],
    "utterance": "Output each object's group and uid fields as a comma-separated string, with one line per object.",
    "expressions": [
      ".[] | [.group, .uid] | join(\",\")",
      ".[] | \"\u007f(.group),\u007f(.uid)\""
    ],
    "data": [
      {
        "input": [
          {
            "timestamp": 1448369447295,
            "group": "employees",
            "uid": "elgalu"
          },
          {
            "timestamp": 1448369447296,
            "group": "employees",
            "uid": "mike"
          },
          {
            "timestamp": 1448369786667,
            "group": "services",
            "uid": "pacts"
          }
        ],
        "output": [
          "employees,elgalu",
          "employees,mike",
          "services,pacts"
        ]
      }
    ],
    "identifier": 33895076
  },
  {
    "context": [
      "What I need is to get\n\n    [{\"name\": \"start\", \"version\": [\"1.0\"]},\n    {\"name\": \"middle\", \"version\": [\"2.0\", \"3.0\"]},\n    {\"name\": \"end\", \"version\": [\"2.0\"]}]\n\nSo I need to remove useless data and then get a list of names with their unique values for \"version\".",
      "But I need to get rid of the duplicated values.\nIs this possible using jq?",
      "You were almost there. Just pipe the `version` array to the `unique` function:\n\n    jq '[.[]|{name, \"version\": [.servers[].version]|unique}]' input",
      "Here is a solution that uses **reduce** to gather version keys in a temporary object and dedup at the end using **keys**\n\n     [\n       . []\n     | reduce .servers[].version as $v (\n         {name, version:{}}\n       ; .version[$v] = 1\n       )\n     | .version |= keys\n     ]"
    ],
    "utterance": "For each entry, output an object with the name and an array of unique version values found in its servers.",
    "expressions": [
      "[.[] | {name, \"version\": [.servers[].version]|unique}]",
      "[ .[] | reduce .servers[].version as $v ( {name, version:{}} ; .version[$v] = 1 ) | .version |= keys ]"
    ],
    "data": [
      {
        "input": [
          {
            "function": "ping",
            "name": "start",
            "servers": [
              {
                "load": 581.6875,
                "last_heard": 2.379324197769165,
                "version": "1.0",
                "hidden": false,
                "pid": "19735"
              },
              {
                "load": 444.0625,
                "last_heard": 1.3227169513702393,
                "version": "1.0",
                "hidden": false,
                "pid": "12092"
              }
            ]
          },
          {
            "function": "pong",
            "name": "middle",
            "servers": [
              {
                "load": 581.6875,
                "last_heard": 2.379324197769165,
                "version": "2.0",
                "hidden": false,
                "pid": "19735"
              },
              {
                "load": 444.0625,
                "last_heard": 1.3227169513702393,
                "version": "3.0",
                "hidden": false,
                "pid": "12092"
              },
              {
                "load": 444.0625,
                "last_heard": 1.3227169513702393,
                "version": "3.0",
                "hidden": false,
                "pid": "12093"
              }
            ]
          },
          {
            "function": "pang",
            "name": "end",
            "servers": [
              {
                "load": 581.6875,
                "last_heard": 2.379324197769165,
                "version": "2.0",
                "hidden": false,
                "pid": "19735"
              },
              {
                "load": 444.0625,
                "last_heard": 1.3227169513702393,
                "version": "2.0",
                "hidden": false,
                "pid": "12092"
              }
            ]
          }
        ],
        "output": [
          {
            "name": "start",
            "version": [
              "1.0"
            ]
          },
          {
            "name": "middle",
            "version": [
              "2.0",
              "3.0"
            ]
          },
          {
            "name": "end",
            "version": [
              "2.0"
            ]
          }
        ]
      }
    ],
    "identifier": 33766735
  },
  {
    "context": [
      "I have a JSON data as follows in data.json file",
      "I want to iterate through the array and extract the value for each element in a loop.",
      "Just use a filter that would return each item in the array.  Then loop over the results, just make sure you use the compact output option (`-c`) so each result is put on a single line and is treated as one item in the loop.",
      "jq -c '.[]' input.json | while read i; do",
      "For the general case, [@Jeff's answer](https://stackoverflow.com/a/33952539/2158479) is the way to go. It uses jq's `--compact-output` (or `-c`) flag to print each iteration result on its own single line, then uses the shell's `read` function in a `while` loop to linewise read the results into a shell variable.",
      "jq -c '.[]' input.json | while read i; do",
      "# do stuff with $i",
      "done"
    ],
    "utterance": "Extract each object from an array, producing one compact-encoded object per line for further processing in a shell loop.",
    "expressions": [
      ".[]",
      "-c .[]"
    ],
    "data": [
      {
        "input": [
          {
            "original_name": "pdf_convert",
            "changed_name": "pdf_convert_1"
          },
          {
            "original_name": "video_encode",
            "changed_name": "video_encode_1"
          },
          {
            "original_name": "video_transcode",
            "changed_name": "video_transcode_1"
          }
        ],
        "output": [
          "{\"original_name\":\"pdf_convert\",\"changed_name\":\"pdf_convert_1\"}",
          "{\"original_name\":\"video_encode\",\"changed_name\":\"video_encode_1\"}",
          "{\"original_name\":\"video_transcode\",\"changed_name\":\"video_transcode_1\"}"
        ]
      }
    ],
    "identifier": 33950596
  },
  {
    "context": [
      "Is there a bash install-able tool I can use to pipe that output and turn it into valid JSON so can be processed by [jq]() given jq [doesn't support it]() ?",
      "$ jq -n -f input.nqj",
      "then the invocation:\n\n    $ jq -n -f input.nqj\n\nwould produce:\n\n    {\n      \"name\": \"Leo\",\n      \"active\": true\n    }"
    ],
    "utterance": "Convert input where keys are unquoted to valid data with quoted keys and parse it so that the object has the key 'name' with value 'Leo' and 'active' with value true",
    "expressions": [
      "jq -n -f input.nqj"
    ],
    "data": [
      {
        "input": "{\n  name: \"Leo\",\n  active: true\n}",
        "output": {
          "name": "Leo",
          "active": true
        }
      }
    ],
    "identifier": 33938284
  },
  {
    "context": [
      "I have files with 1 json document per row and the fields `start_id` and `end_id` in each document. I'd like to use jq to extract these and print them on the same row.",
      "So far I have:\n\n    cat part* | jq '\"\\(.start_id) \\(.end_id)\"' | sed s/\\\"//g | head\n\nThis works, but I need the `sed` to remove the double quotes.\n\nIn order to improve my jq-foo, is there a way to do this _without using sed_?",
      "By default, `jq` formats its output to be a valid JSON value. This means that character strings are wrapped in quotes.",
      "Fortunately, the `--raw-output` or `-r` parameter overrides that behaviour so your string output can be free of those nasty quotation marks."
    ],
    "utterance": "Print the values of start_id and end_id fields on each row, space separated and without surrounding double quotes.",
    "expressions": [
      ".start_id, .end_id | \"\u001b[1A\"][0m[0m[01m][36m\u001b[01;36m\\(.start_id) \\(.end_id)\u001b[0m",
      "-r '.start_id, .end_id | \"\\(.start_id) \\(.end_id)\"'",
      "-r '\"\\(.start_id) \\(.end_id)\"'",
      "--raw-output '\"\\(.start_id) \\(.end_id)\"'"
    ],
    "data": [
      {
        "input": [
          {
            "start_id": 1,
            "end_id": 50
          },
          {
            "start_id": 50,
            "end_id": 99
          },
          {
            "start_id": 99,
            "end_id": 12
          }
        ],
        "output": [
          "1 50",
          "50 99",
          "99 12"
        ]
      }
    ],
    "identifier": 33947584
  },
  {
    "context": [
      "So, the existing entry `\"Value\": \"123.123.123.123\"` needs to remain, but needs to have additional entry of `\"Value\": \"456.456.456.456\"`.",
      "You're adding an object to that array, not a string. Create an object to be inserted.",
      ".Changes[].ResourceRecordSet.ResourceRecords += [{Value:\"456.456.456.456\"}]"
    ],
    "utterance": "Add an additional object with Value equal to \"456.456.456.456\" to each ResourceRecords array within all Changes.",
    "expressions": [
      ".Changes[].ResourceRecordSet.ResourceRecords += [{Value:\"456.456.456.456\"}]"
    ],
    "data": [
      {
        "input": {
          "Comment": "Update 'A' record for drivepoc.biz zone file",
          "Changes": [
            {
              "Action": "UPSERT",
              "ResourceRecordSet": {
                "Name": "www.domain.biz.",
                "Type": "A",
                "TTL": 60,
                "ResourceRecords": [
                  {
                    "Value": "123.123.123.123"
                  }
                ]
              }
            }
          ]
        },
        "output": {
          "Comment": "Update 'A' record for drivepoc.biz zone file",
          "Changes": [
            {
              "Action": "UPSERT",
              "ResourceRecordSet": {
                "Name": "www.domain.biz.",
                "Type": "A",
                "TTL": 60,
                "ResourceRecords": [
                  {
                    "Value": "123.123.123.123"
                  },
                  {
                    "Value": "456.456.456.456"
                  }
                ]
              }
            }
          ]
        }
      }
    ],
    "identifier": 34076779
  },
  {
    "context": [
      "I am trying to find the server id for which the addr value is 10.3.3.18. How can I achieve that?",
      "You want something like the following:",
      "jq '.servers[]|select(.addresses.services_z1[].addr==\"10.3.3.18\")|.id'",
      "This says to look through all of the servers, match those that have .addresses.services_z1[].addr==\"10.3.3.18\", and then print the id of those servers."
    ],
    "utterance": "Find the id of the server where an address in services_z1 has addr equal to 10.3.3.18.",
    "expressions": [
      ".servers[] | select(.addresses.services_z1[].addr==\"10.3.3.18\") | .id"
    ],
    "data": [
      {
        "input": {
          "servers": [
            {
              "id": "1",
              "addresses": {
                "services_z1": [
                  {
                    "OS-EXT-IPS-MAC:mac_addr": "fa:16:3e:bc:db:7d",
                    "addr": "10.3.3.18",
                    "version": 4,
                    "OS-EXT-IPS:type": "fixed"
                  }
                ]
              }
            },
            {
              "id": "2",
              "addresses": {
                "services_z1": [
                  {
                    "OS-EXT-IPS-MAC:mac_addr": "fa:16:3e:bc:db:7d",
                    "addr": "10.3.3.19",
                    "version": 4,
                    "OS-EXT-IPS:type": "fixed"
                  }
                ]
              }
            },
            {
              "id": "3",
              "addresses": {
                "services_z1": [
                  {
                    "OS-EXT-IPS-MAC:mac_addr": "fa:16:3e:bc:db:7d",
                    "addr": "10.3.3.20",
                    "version": 4,
                    "OS-EXT-IPS:type": "fixed"
                  }
                ]
              }
            },
            {
              "id": "4",
              "addresses": {
                "services_z1": [
                  {
                    "OS-EXT-IPS-MAC:mac_addr": "fa:16:3e:bc:db:7d",
                    "addr": "10.3.3.21",
                    "version": 4,
                    "OS-EXT-IPS:type": "fixed"
                  }
                ]
              }
            }
          ]
        },
        "output": "1"
      }
    ],
    "identifier": 33994887
  },
  {
    "context": [
      ".fields.customfield_10025 | if .value != null then (.value + \",\" + .child.value ) else \"\" end",
      "when I move my filter in a larger filter seen below, I get an error: Cannot index string with string \"value\"",
      "Try putting parentheses around the expression:",
      ".fields.customfield_10025 | if .value != null then (.value + \",\" + .child.value ) else \"\" end",
      "That is, `[1,2 | type]` is parsed as `[(1,2) | type]`, not `[1, (2|type)]`."
    ],
    "utterance": "Concatenate .value and .child.value from the customfield_10025 object with a comma separator, or return an empty string if .value is null, within an array mapping.",
    "expressions": [
      "map([.key, .fields.project.name, .fields.parent.key, .fields.issuetype.name, .fields.status.name, .fields.priority.name, .fields.resolution.name, .fields.assignee.name, .fields.reporter.name, .fields.created, .fields.updated, .fields.resolutiondate, .fields.summary, (.fields.components | (map(.name?) | join(\",\"))), (.fields.fixVersions | (map(.name?) | join(\",\"))), (.fields.customfield_10025 | if .value != null then (.value + \",\" + .child.value) else \"\" end), .fields.customfield_10201] | join(\"---\"))"
    ],
    "identifier": 33903013
  },
  {
    "context": [
      "I am trying to extract values from it to create this line using jq:\r\n\r\n    15226, host1, Group 1, Group 2",
      "jq -r '.result[] | .hostid + \", \" + .host + \", \" + .groups[].name' hostlist.json",
      "You can use this:\r\n\r\n    jq -r '.result[]|[.hostid,.host,.groups[].name]|@csv'\r\n\r\nOutput:\r\n\r\n    \"15226\",\"host1\",\"Group 1\",\"Group 2\"",
      "If you don't like that, a simple join(',') should be enough:\r\n\r\n    jq -r '.result[]|[.hostid,.host,.groups[].name]|join(\",\")'\r\n\r\nOutput:\r\n\r\n    15226,host1,Group 1,Group 2"
    ],
    "utterance": "Combine hostid, host, and all group names from each result entry into a single comma-separated line.",
    "expressions": [
      ".result[] | [.hostid, .host, .groups[].name] | join(\", \")",
      ".result[] | [.hostid, .host, .groups[].name] | @csv"
    ],
    "data": [
      {
        "input": {
          "jsonrpc": "2.0",
          "result": [
            {
              "hostid": "15226",
              "host": "host1",
              "groups": [
                {
                  "groupid": "56",
                  "name": "Group 1",
                  "internal": "0",
                  "flags": "0"
                },
                {
                  "groupid": "112",
                  "name": "Group 2",
                  "internal": "0",
                  "flags": "0"
                }
              ]
            }
          ],
          "id": 1
        },
        "output": "15226,host1,Group 1,Group 2"
      }
    ],
    "identifier": 33919650
  },
  {
    "context": [
      "I would like to construct a filter, that based upon the object type, say \"Type2\", deletes or clears a property of that object, say Property2.",
      "(.[] | select(.Type == \"Type2\")).Properties |= del(.Property2)",
      ".[] |= (if .Type == \"Type2\" then delpaths([[\"Properties\", \"Property2\"]]) else . end)",
      "del(.[] | select(.Type == \"Type2\").Properties.Property2)"
    ],
    "utterance": "Delete Property2 from Properties of objects where Type equals \"Type2\".",
    "expressions": [
      "(.[] | select(.Type == \"Type2\")).Properties |= del(.Property2)",
      ".[] |= (if .Type == \"Type2\" then delpaths([[\"Properties\", \"Property2\"]]) else . end)",
      "del(.[] | select(.Type == \"Type2\").Properties.Property2)"
    ],
    "data": [
      {
        "input": {
          "object1": {
            "Type": "Type1",
            "Properties": {
              "Property1": "blablabla",
              "Property2": [
                {
                  "Key": "Name",
                  "Value": "xxx"
                },
                {
                  "Key": "Surname",
                  "Value": "yyy"
                }
              ],
              "Property3": "xxx"
            }
          },
          "object2": {
            "Type": "Type2",
            "Properties": {
              "Property1": "blablabla",
              "Property2": [
                {
                  "Key": "Name",
                  "Value": "xxx"
                },
                {
                  "Key": "Surname",
                  "Value": "yyy"
                }
              ],
              "Property3": "xxx"
            }
          }
        },
        "output": {
          "object1": {
            "Type": "Type1",
            "Properties": {
              "Property1": "blablabla",
              "Property2": [
                {
                  "Key": "Name",
                  "Value": "xxx"
                },
                {
                  "Key": "Surname",
                  "Value": "yyy"
                }
              ],
              "Property3": "xxx"
            }
          },
          "object2": {
            "Type": "Type2",
            "Properties": {
              "Property1": "blablabla",
              "Property3": "xxx"
            }
          }
        }
      }
    ],
    "identifier": 34142687
  },
  {
    "context": [
      "I would like to construct a jq-filter enabling me to filter out specific resources based on (one or multiple) of their property fields.",
      "when filtering for Type=\"AWS::EC2::InternetGateway\" the result should be",
      "You can use `or` if you want to filter by multiple conditions, like this:\n\n    jq '.Resources[]|select(.Type==\"AWS::EC2::VPC\" or .Type==\"foo\")' aws.json",
      "{\n  \"Resources\": {\n    \"ig001\": {\n      \"Type\": \"AWS::EC2::InternetGateway\", ...",
      "Here is a solution which uses a separate function to select all resources matching a specified condition which is passed a {key,value} pair for each resource.\n\n    def condition:\n      .value.Type == \"AWS::EC2::VPC\"\n    ;\n\n    {\n      Resources: .Resources | with_entries(select(condition))\n    }",
      "I found one way to do this without defining a function:\n```\njq '.Resources | to_entries[] | select(.value.Type == \"AWS::EC2::InternetGateway\")|[{key: .key, value: .value}]|from_entries' example.json\n```"
    ],
    "utterance": "Return only the resources where the Type is equal to \"AWS::EC2::InternetGateway\".",
    "expressions": [
      ".Resources | to_entries[] | select(.value.Type == \"AWS::EC2::InternetGateway\") | [{key: .key, value: .value}] | from_entries",
      "{ Resources: .Resources | with_entries(select(.value.Type == \"AWS::EC2::InternetGateway\")) }"
    ],
    "data": [
      {
        "input": {
          "Resources": {
            "vpc001": {
              "Type": "AWS::EC2::VPC",
              "Properties": {
                "CidrBlock": "10.1.0.0/16",
                "InstanceTenancy": "default",
                "EnableDnsSupport": "true",
                "EnableDnsHostnames": "true"
              }
            },
            "ig001": {
              "Type": "AWS::EC2::InternetGateway",
              "Properties": {
                "Tags": [
                  {
                    "Key": "Name",
                    "Value": "ig001"
                  }
                ]
              }
            }
          }
        },
        "output": {
          "ig001": {
            "Type": "AWS::EC2::InternetGateway",
            "Properties": {
              "Tags": [
                {
                  "Key": "Name",
                  "Value": "ig001"
                }
              ]
            }
          }
        }
      }
    ],
    "identifier": 34105038
  },
  {
    "context": [
      "Using `jq` I want to separate the ip addresses in the `ip` array, like this:\r\n\r\n    [\r\n      {\r\n        \"ip\": \"8.8.4.4/32\",\r\n        \"port\": 25,\r\n        \"proto\": \"tcp\"\r\n      },\r\n      {\r\n        \"ip\": \"212.40.11.20/32\",\r\n        \"port\": 25,\r\n        \"proto\": \"tcp\"\r\n      },\r\n      {\r\n        \"ip\": \"212.40.11.30/32\",\r\n        \"port\": 3389,\r\n        \"proto\": \"tcp\"\r\n      }\r\n    ]",
      "$ jq 'map(  (.ip[] | { \"ip\": .}) + del(.ip) )' input.json",
      "Equivalently, one can write `map( . + {ip:.ip[]} )`.",
      "Alternatively ... you can use the following expression:\r\n\r\n    jq '[.[]|{ip:.ip[],port,proto}]' aws.json",
      "A shorter and simpler alternative ...\r\n\r\n    jq 'map(.ip = .ip[])'"
    ],
    "utterance": "Expand each object with multiple IP addresses into separate objects, one for each IP, carrying over port and proto fields.",
    "expressions": [
      "map((.ip[] | { \"ip\": . }) + del(.ip))",
      "map(. + {ip:.ip[]})",
      "[.[] | {ip:.ip[],port,proto}]",
      "map(.ip = .ip[])"
    ],
    "data": [
      {
        "input": [
          {
            "ip": [
              "8.8.4.4/32",
              "212.40.11.20/32"
            ],
            "port": 25,
            "proto": "tcp"
          },
          {
            "ip": [
              "212.40.11.30/32"
            ],
            "port": 3389,
            "proto": "tcp"
          }
        ],
        "output": [
          {
            "ip": "8.8.4.4/32",
            "port": 25,
            "proto": "tcp"
          },
          {
            "ip": "212.40.11.20/32",
            "port": 25,
            "proto": "tcp"
          },
          {
            "ip": "212.40.11.30/32",
            "port": 3389,
            "proto": "tcp"
          }
        ]
      }
    ],
    "identifier": 34118786
  },
  {
    "context": [
      "But I can't test for the containment of a character class (in this example, a digit):",
      "$ echo '\"f1\"' | jq 'test(\"\\d\")'",
      "jq: error: Invalid escape at line 1, column 4 (while parsing '\"\\d\"') at <top-    level>, line 1:",
      "I need to double-escape the \\.",
      "$ echo '\"f1\"' | jq 'test(\"\\\\d\")'",
      "true"
    ],
    "utterance": "Test whether a string contains a digit using the digit character class.",
    "expressions": [
      "test(\"\\\\d\")"
    ],
    "data": [
      {
        "input": "f1",
        "output": true
      }
    ],
    "identifier": 34168623
  },
  {
    "context": [
      "I have files with json structure like this:\r\n\r\n    [\r\n      {\r\n        \"uid\": 11111,\r\n        \"something\": {\r\n    \t\t(...)\r\n        }\r\n      },\r\n      {\r\n        \"uid\": 22222,\r\n        \"something\": {\r\n    \t\t(...)\r\n        }\r\n      }\r\n    ]",
      "i'd like to know which part is from which file, so i need to group it in some way.",
      "my idea is to move content of each file to higher (parent) object with own members.",
      "function mycat {\r\n      for file\r\n      do\r\n        jq --arg file \"$file\" '{\"file\": $file, \"contents\": .}' \"$file\"\r\n      done\r\n    }",
      "jq '{file: input_filename, contents: .}' FILELIST"
    ],
    "utterance": "Wrap each file's contents in an object containing the file name and its contents as members.",
    "expressions": [
      "jq --arg file \"$file\" '{\"file\": $file, \"contents\": .}' \"$file\"",
      "jq '{file: input_filename, contents: .}' FILELIST"
    ],
    "identifier": 34197900
  },
  {
    "context": [
      "And I want an array of `jq` index paths that contain `foo`:",
      "[\n    \".json[1][2][1]\",\n    \".json[1][3][0][1]\"\n]",
      "We can thus obtain all leaf paths in the given JSON and iterate through them, select those for which their value in the input JSON is \"foo\", and generate an array out of them:",
      "jq '[paths as $path | select(getpath($path) == \"foo\") | $path]'",
      "it is possible to convert these arrays to the jq path strings you seek by transforming each path through the following script:",
      "\".\\(map(\"[\\(tojson)]\") | join(\"\"))\"",
      "The full script would therefore be:",
      "jq '[paths as $path | select(getpath($path) == \"foo\") | $path | \".\\(map(\"[\\(tojson)]\") | join(\"\"))\"]'",
      "Santiago's excellent program can be further tweaked to produce output in the requested format:",
      "def jqpath:\n  def t: test(\"^[A-Za-z_][A-Za-z0-9_]*$\");\n  reduce .[] as $x\n    (\"\";\n     if ($x|type) == \"string\"\n     then . + ($x | if t then \".\\(.)\" else  \".[\" + tojson + \"]\" end)\n     else . + \"[\\($x)]\"\n     end);",
      "[paths as $path | select( getpath($path) == \"foo\" ) | $path | jqpath]",
      "[\n  \".json[1][2][1]\",\n  \".json[1][3][0][1]\"\n]"
    ],
    "utterance": "Produce an array of path expressions identifying all locations in the data where the value is \"foo\".",
    "expressions": [
      "[paths as $path | select(getpath($path) == \"foo\") | $path | \".\\(map(\"[\\(tojson)]\") | join(\"\"))\"]",
      "def jqpath:\n  def t: test(\"^[A-Za-z_][A-Za-z0-9_]*$\");\n  reduce .[] as $x\n    (\"\";\n     if ($x|type) == \"string\"\n     then . + ($x | if t then \".\\(.)\" else  \".[\" + tojson + \"]\" end)\n     else . + \"[\\($x)]\"\n     end);\n[paths as $path | select(getpath($path) == \"foo\") | $path | jqpath]"
    ],
    "data": [
      {
        "input": {
          "json": [
            "a",
            [
              "b",
              "c",
              [
                "d",
                "foo",
                1
              ],
              [
                [
                  42,
                  "foo"
                ]
              ]
            ]
          ]
        },
        "output": [
          ".json[1][2][1]",
          ".json[1][3][0][1]"
        ]
      }
    ],
    "identifier": 34165201
  },
  {
    "context": [
      "I have some fields that are really long, but I just want to see the beginning of them. Is there a way to truncate a field to only the first X characters?",
      "e.g., trimming a string to the first 10 characters",
      "$ echo '\"12345678901234567890\"' | jq '.[0:10]'",
      "Read, take the first 0-10 characters of the string.",
      "If you want to recursively trim all strings:",
      ".. |= (if type == \"string\" then .[0:2] else . end)",
      "For example, if the input is:",
      "{ \"a\": \"aaaaaaaaaaaaaaaaaaaaaaaaaaaa\", \n  \"b\": \"bbbbbbbbbbbbbbbbbbbbbbbbbb\",\n  \"c\": [\"ddddddddddddddd\"]\n}",
      "the output (compacted) would be:\n{ \"a\":\"aa\",\"b\":\"bb\",\"c\":[\"dd\"]}"
    ],
    "utterance": "Truncate all string fields, at any depth, to the first 2 characters.",
    "expressions": [
      ".. |= (if type == \"string\" then .[0:2] else . end)"
    ],
    "data": [
      {
        "input": {
          "a": "aaaaaaaaaaaaaaaaaaaaaaaaaaaa",
          "b": "bbbbbbbbbbbbbbbbbbbbbbbbbb",
          "c": [
            "ddddddddddddddd"
          ]
        },
        "output": {
          "a": "aa",
          "b": "bb",
          "c": [
            "dd"
          ]
        }
      }
    ],
    "identifier": 34212688
  },
  {
    "context": [
      "I want to get the output file like this, to change the owner's type to the user's name:",
      "(.users | add) as $users\n    | (.messages[].owner |= (.type = $users[.id]))\n    | (.messages[].otherUser |= (.type = $users[.id]))",
      "($users | map(.users) | add) as $dict\n| walk(if type == \"object\" and .type == \"user\"\n       then .type = $dict[.id]\n       else .\n       end)"
    ],
    "utterance": "For each message object, set the owner.type and otherUser.type fields to the corresponding user name from the users list, matching by id.",
    "expressions": [
      "(.users | add) as $users | (.messages[].owner |= (.type = $users[.id])) | (.messages[].otherUser |= (.type = $users[.id]))",
      "($users | map(.users) | add) as $dict | walk(if type == \"object\" and .type == \"user\" then .type = $dict[.id] else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "users": {
              "347793": "user1"
            }
          },
          {
            "users": {
              "6560536": "user2"
            }
          },
          {
            "users": {
              "6637901": "user3"
            }
          },
          {
            "users": {
              "5850517": "user4"
            }
          },
          {
            "users": {
              "2907509": "user5"
            }
          },
          {
            "users": {
              "6611743": "user6"
            }
          },
          {
            "users": {
              "6535592": "user7"
            }
          },
          {
            "users": {
              "5586286": "user8"
            }
          },
          {
            "users": {
              "2484439": "user9"
            }
          },
          {
            "messages": {
              "id": "id1",
              "owner": {
                "id": "347793",
                "type": "user"
              },
              "otherUser": {
                "id": "6560536",
                "type": "user"
              }
            }
          },
          {
            "messages": {
              "id": "id2",
              "owner": {
                "id": "6637901",
                "type": "user"
              },
              "otherUser": {
                "id": "6560536",
                "type": "user"
              }
            }
          },
          {
            "messages": {
              "id": "id3",
              "owner": {
                "id": "2907509",
                "type": "user"
              },
              "otherUser": {
                "id": "2484439",
                "type": "user"
              }
            }
          },
          {
            "messages": {
              "id": "id4",
              "owner": {
                "id": "347793",
                "type": "user"
              },
              "otherUser": {
                "id": "2907509",
                "type": "user"
              }
            }
          },
          {
            "messages": {
              "id": "id5",
              "owner": {
                "id": "5850517",
                "type": "user"
              },
              "otherUser": {
                "id": "5850517",
                "type": "user"
              }
            }
          },
          {
            "messages": {
              "id": "id6",
              "owner": {
                "id": "5586286",
                "type": "user"
              },
              "otherUser": {
                "id": "347793",
                "type": "user"
              }
            }
          }
        ],
        "output": [
          {
            "users": {
              "347793": "user1"
            }
          },
          {
            "users": {
              "6560536": "user2"
            }
          },
          {
            "users": {
              "6637901": "user3"
            }
          },
          {
            "users": {
              "5850517": "user4"
            }
          },
          {
            "users": {
              "2907509": "user5"
            }
          },
          {
            "users": {
              "6611743": "user6"
            }
          },
          {
            "users": {
              "6535592": "user7"
            }
          },
          {
            "users": {
              "5586286": "user8"
            }
          },
          {
            "users": {
              "2484439": "user9"
            }
          },
          {
            "messages": {
              "id": "id1",
              "owner": {
                "id": "347793",
                "type": "user1"
              },
              "otherUser": {
                "id": "6560536",
                "type": "user2"
              }
            }
          },
          {
            "messages": {
              "id": "id2",
              "owner": {
                "id": "6637901",
                "type": "user3"
              },
              "otherUser": {
                "id": "6560536",
                "type": "user2"
              }
            }
          },
          {
            "messages": {
              "id": "id3",
              "owner": {
                "id": "2907509",
                "type": "user5"
              },
              "otherUser": {
                "id": "2484439",
                "type": "user9"
              }
            }
          },
          {
            "messages": {
              "id": "id4",
              "owner": {
                "id": "347793",
                "type": "user1"
              },
              "otherUser": {
                "id": "2907509",
                "type": "user5"
              }
            }
          },
          {
            "messages": {
              "id": "id5",
              "owner": {
                "id": "5850517",
                "type": "user4"
              },
              "otherUser": {
                "id": "5850517",
                "type": "user4"
              }
            }
          },
          {
            "messages": {
              "id": "id6",
              "owner": {
                "id": "5586286",
                "type": "user8"
              },
              "otherUser": {
                "id": "347793",
                "type": "user1"
              }
            }
          }
        ]
      }
    ],
    "identifier": 33729261
  },
  {
    "context": [
      "How do I get **jq** to take json like this:\r\n\r\n    {\r\n      \"host1\": { \"ip\": \"10.1.2.3\" },\r\n      \"host2\": { \"ip\": \"10.1.2.2\" },\r\n      \"host3\": { \"ip\": \"10.1.18.1\" }\r\n    }\r\n\r\nand generate this output:\r\n\r\n    host1, 10.1.2.3\r\n    host2, 10.1.2.2\r\n    host3, 10.1.18.1\r\n\r\nI'm not interested in the formatting, I just can't figure out how to access the key name and value.",
      "So one solution to your particular problem would be:\r\n    jq -r 'keys[] as $k | \"\\($k), \\(.[$k] | .ip)\"' ",
      "Another alternative, which produces keys in the original order, is: \r\n    jq -r 'to_entries[] | \"\\(.key), \\(.value | .ip)\"'",
      "The @csv and @tsv filters might also be worth considering here, e.g.\r\n    jq -r 'to_entries[] | [.key, .value.ip] | @tsv'",
      "Came across very elegant solution\r\n    jq 'with_entries(.value |= .ip)'"
    ],
    "utterance": "List each top-level key and the corresponding 'ip' field from its value as pairs.",
    "expressions": [
      "keys[] as $k | \"\\($k), \\(.[$k] | .ip)\"",
      "to_entries[] | \"\\(.key), \\(.value | .ip)\"",
      "to_entries[] | [.key, .value.ip] | @tsv",
      "with_entries(.value |= .ip)"
    ],
    "data": [
      {
        "input": {
          "host1": {
            "ip": "10.1.2.3"
          },
          "host2": {
            "ip": "10.1.2.2"
          },
          "host3": {
            "ip": "10.1.18.1"
          }
        },
        "output": [
          "host1, 10.1.2.3",
          "host2, 10.1.2.2",
          "host3, 10.1.18.1"
        ]
      }
    ],
    "identifier": 34226370
  },
  {
    "context": [
      "I have, for complicated reasons involving a trip from an Apple plist through `xml2json`, a number of JSON files with data in this form:\r\n\r\n    { \r\n      \"key\": [ \"key1\", \"key2\", \"key3\" ],\r\n      \"string\": [ \"value1\", \"value2\", \"value3\" ]\r\n    }\r\n\r\nAnd I would like to convert that to a normal JSON object:\r\n\r\n    { \r\n      \"key1\": \"value1\",\r\n      \"key2\": \"value2\",\r\n      \"key3\": \"value3\"     \r\n    }",
      "jq '[range(.key | length) as $i | {(.key[$i]): .string[$i]}] | add'",
      "jq '[.key, .string] | transpose | map({key: .[0], value: .[1]}) | from_entries'",
      "jq '[.key, .string] | transpose | map({(.[0]): .[1]}) | add'",
      ".string as $v\n| reduce .key[] as $k (\n   {idx:0, result:{}}; .result[$k] = $v[.idx] | .idx += 1\n  )\n| .result"
    ],
    "utterance": "Convert an object with arrays 'key' and 'string' into a single object where each element in 'key' is a property and the value is the corresponding element from 'string'.",
    "expressions": [
      ". as $d | [range(.key|length)|{\"key\":$d.key[.],\"value\":$d.string[.]}] | from_entries",
      "[range(.key | length) as $i | {(.key[$i]): .string[$i]}] | add",
      "[.key, .string] | transpose | map({key: .[0], value: .[1]}) | from_entries",
      "[.key, .string] | transpose | map({(.[0]): .[1]}) | add",
      ".string as $v | reduce .key[] as $k ({idx:0, result:{};} ; .result[$k] = $v[.idx] | .idx += 1) | .result"
    ],
    "data": [
      {
        "input": {
          "key": [
            "key1",
            "key2",
            "key3"
          ],
          "string": [
            "value1",
            "value2",
            "value3"
          ]
        },
        "output": {
          "key1": "value1",
          "key2": "value2",
          "key3": "value3"
        }
      }
    ],
    "identifier": 34212371
  },
  {
    "context": [
      "I am trying to access the field \"my-tag\" from the following json using jq from a shell script:",
      "search=\"my-tag\"",
      "value=($(jq \".${search}.value\" \"$file\"))",
      "error: tag is not defined",
      "You'll have to use the associative array notation for arbitrary key strings",
      "jq \".[\\\"$search\\\"].value\" \"$file",
      "As a general rule of thumb, I would strongly suggest ... use arguments to pass them in.",
      "jq --arg search \"$search\" '.[$search].value' \"$file\""
    ],
    "utterance": "Extract the value of the field named 'my-tag', where the field name is stored in a shell variable.",
    "expressions": [
      "jq \".[\\\"$search\\\"].value\" \"$file\"",
      "jq --arg search \"$search\" '.[$search].value' \"$file\""
    ],
    "data": [
      {
        "input": {
          "tag": {
            "value": "hello"
          },
          "my-tag": {
            "value": "hello-my-tag"
          }
        },
        "output": "hello-my-tag"
      }
    ],
    "identifier": 34338427
  },
  {
    "context": [
      "I have a json file that contains a string of json within an object:",
      "\"response\": {\n    \"size\": 78,\n    \"text\": \"{\\\"recordID\\\":123, \\\"title\\\":\\\"Hello World\\\", \\\"content\\\":\\\"Lorem ipsum...\\\"}\"",
      "Is there some way to convert a string of escaped json to actual json that I can parse with a command such as this: jq '.response.text | @json | .title' and get this output: \"Hello World\"?",
      "Use [fromjson](https://jqlang.github.io/jq/manual/#convert-to-from-json).",
      "So you could do this:\n\n    .response.text | fromjson.title"
    ],
    "utterance": "Extract the value of the title field from an object embedded as a string inside the text field of the response object.",
    "expressions": [
      ".response.text | fromjson | .title",
      ".response.text | fromjson.title"
    ],
    "data": [
      {
        "input": {
          "requestType": "POST",
          "response": {
            "size": 78,
            "text": "{\"recordID\":123, \"title\":\"Hello World\", \"content\":\"Lorem ipsum...\"}"
          }
        },
        "output": "Hello World"
      }
    ],
    "identifier": 34340549
  },
  {
    "context": [
      "I have been looking for a way to produce from each of these line the following:\r\n\r\n    [field1,field2,field3,author1,author_type1]\r\n    [field1,field2,field3,author2,author_type2]\r\n    ...",
      "Jeff's suggestion to use a one-step approach makes sense, but if one did have to translate the array `[field1,field2,field3,[author1,...,authorN],[author_type1,...,author_typeN]]` to a stream of arrays of the form `[field1,field2,field3,authorI,author_typeI]` then a suitable jq filter would be:\r\n\r\n    .[0:2] + ([.[3], .[4]] | transpose[])"
    ],
    "utterance": "Transform a list structured as [field1, field2, field3, [author1, ..., authorN], [author_type1, ..., author_typeN]] into a set of arrays where each array contains field1, field2, field3, authorI, and author_typeI for each author.",
    "expressions": [
      ".[0:2] + ([.[3], .[4]] | transpose[])"
    ],
    "data": [
      {
        "input": [
          "f1",
          "f2",
          "f3",
          [
            "a1",
            "a2"
          ],
          [
            "t1",
            "t2"
          ]
        ],
        "output": [
          [
            "f1",
            "f2",
            "f3",
            "a1",
            "t1"
          ],
          [
            "f1",
            "f2",
            "f3",
            "a2",
            "t2"
          ]
        ]
      }
    ],
    "identifier": 34343151
  },
  {
    "context": [
      "I would like to use `jq` to turn an array of objects into an object of arrays.",
      "I would like to merge them together to form:\n\n    {\n      \"key1\": [5, 2]\n      \"key2\": [10, null]\n    }",
      "The jq command needs to work for an arbitrary number of files (more than 2).",
      "def merge:\n  def allkeys: map(keys) | add | unique;\n  allkeys as $allkeys\n  | reduce .[] as $in ({};\n     reduce $allkeys[] as $k (.;\n       . + {($k): (.[$k] + [$in[$k]]) } ));\n\nmerge",
      "$ jq -s -f merge.jq file*.json",
      "(add | keys) as $all                                                  # get all keys\n| map( . as $o | reduce $all[] as $k ({}; .[$k] = $o[$k]) )             # normalize objects\n|    ( . as $a | reduce $all[] as $k ({}; .[$k] = ($a | map(.[$k]))) )  # transpose",
      "$ jq -s -f filter.jq file1.json file2.json",
      "Sample output:\n\n    {\n      \"key1\": [\n        5,\n        2\n      ],\n      \"key2\": [\n        10,\n        null\n      ]\n    }"
    ],
    "utterance": "Combine multiple objects so each key maps to an array of values (using null for missing keys), handling any number of input files.",
    "expressions": [
      "def merge:\n  def allkeys: map(keys) | add | unique;\n  allkeys as $allkeys\n  | reduce .[] as $in ({};\n     reduce $allkeys[] as $k (.;\n       . + {($k): (.[$k] + [$in[$k]]) } ));\n\nmerge",
      "(add | keys) as $all\n| map( . as $o | reduce $all[] as $k ({}; .[$k] = $o[$k]) )\n| ( . as $a | reduce $all[] as $k ({}; .[$k] = ($a | map(.[$k]))) )"
    ],
    "data": [
      {
        "input": [
          {
            "key1": 5,
            "key2": 10
          },
          {
            "key1": 2
          }
        ],
        "output": {
          "key1": [
            5,
            2
          ],
          "key2": [
            10,
            null
          ]
        }
      },
      {
        "input": [
          {
            "key1": 5,
            "key2": 10
          },
          {
            "key1": 2
          },
          {
            "key3": 2
          }
        ],
        "output": {
          "key1": [
            5,
            2,
            null
          ],
          "key2": [
            10,
            null,
            null
          ],
          "key3": [
            null,
            null,
            2
          ]
        }
      }
    ],
    "identifier": 34273921
  },
  {
    "context": [
      "Need help to parse and print only `category` values either using jq or jsawk or shell script.",
      ".. | objects.category // empty",
      "This returns the following strings:",
      "\"cocker spaniel\"",
      "\"dog\"",
      "leaf_paths | select(.[-1] == \"category\") as $p | getpath($p)"
    ],
    "utterance": "Extract and print all values with the key 'category', regardless of where they appear in the data.",
    "expressions": [
      ".. | objects.category // empty",
      "(leaf_paths | select(.[-1] == \"category\")) as $p | getpath($p)"
    ],
    "data": [
      {
        "input": {
          "fine_grained": {
            "dog": [
              {
                "category": "cocker spaniel",
                "mark": 0.9958831668
              }
            ]
          },
          "coarse": [
            {
              "category": "dog",
              "mark": 0.948208034
            }
          ]
        },
        "output": [
          "cocker spaniel",
          "dog"
        ]
      }
    ],
    "identifier": 34426441
  },
  {
    "context": [
      "I just want the name of the index and the memory_size column from \"total\".",
      "But I was hoping to iterate through using some sort of wild card for the index name.",
      "jq -r  '\n  .indices\n  | to_entries[]\n  | \"\\(.key) \\(.value.total.filter_cache.memory_size)\"\n' input.json",
      ".indices\n| keys[] as $k\n| \"\\($k) \\(.[$k].total.filter_cache.memory_size)\""
    ],
    "utterance": "List each index name with its corresponding total.filter_cache.memory_size value.",
    "expressions": [
      ".indices | to_entries[] | \"\\(.key) \\(.value.total.filter_cache.memory_size)\"",
      ".indices | keys[] as $k | \"\\($k) \\(.[$k].total.filter_cache.memory_size)\""
    ],
    "data": [
      {
        "input": {
          "_shards": {
            "total": 5662,
            "successful": 5662,
            "failed": 0
          },
          "_all": {
            "primaries": {
              "filter_cache": {
                "memory_size": "32.8gb",
                "memory_size_in_bytes": 35245081088,
                "evictions": 31347095
              }
            },
            "total": {
              "filter_cache": {
                "memory_size": "94.3gb",
                "memory_size_in_bytes": 101307321504,
                "evictions": 79329152
              }
            }
          },
          "indices": {
            "oreserverdk04180047": {
              "primaries": {
                "filter_cache": {
                  "memory_size": "0b",
                  "memory_size_in_bytes": 0,
                  "evictions": 11
                }
              },
              "total": {
                "filter_cache": {
                  "memory_size": "0b",
                  "memory_size_in_bytes": 0,
                  "evictions": 132
                }
              }
            },
            "janbe10200002": {
              "primaries": {
                "filter_cache": {
                  "memory_size": "0b",
                  "memory_size_in_bytes": 0,
                  "evictions": 88
                }
              },
              "total": {
                "filter_cache": {
                  "memory_size": "0b",
                  "memory_size_in_bytes": 0,
                  "evictions": 119
                }
              }
            }
          }
        },
        "output": [
          "oreserverdk04180047 0b",
          "janbe10200002 0b"
        ]
      }
    ],
    "identifier": 34425957
  },
  {
    "context": [
      "To fix your particular problem, you just need to provide a string value for when there is no `instanceType`.\r\n\r\n    .products[] | select(.attributes.instanceType // \"\" | endswith($type)).sku",
      "So I'd suggest starting off by modifying your program to handle the case that .attributes.instanceType is not a string.\r\n\r\nFor example:\r\n\r\n    select( .attributes.instanceType | (type == \"string\" and endswith($type)) )"
    ],
    "utterance": "Find the 'sku' for products where the '.attributes.instanceType' value ends with 'hs1.8xlarge', handling cases where 'instanceType' may be missing or not a string.",
    "expressions": [
      ".products[] | select(.attributes.instanceType // \"\" | endswith($type)).sku",
      ".products[] | select(.attributes.instanceType | (type == \"string\" and endswith($type))).sku"
    ],
    "identifier": 34515382
  },
  {
    "context": [
      "I would like to convert the stream of objects:\r\n\r\n    {\r\n      \"a\": \"green\",\r\n      \"b\": \"white\"\r\n    }\r\n    {\r\n      \"a\": \"red\",\r\n      \"c\": \"purple\"\r\n    }\r\n\r\ninto one object:\r\n\r\n    {\r\n      \"a\": \"red\",\r\n      \"b\": \"white\",\r\n      \"c\": \"purple\"\r\n    }",
      "Thus one way to combine objects in the input stream is to use:\r\n\r\n    jq -s add",
      "For the first problem (reduction), rather than slurping (whether via the -s option, or using `[inputs]`), it would be more efficient to use `reduce` with `inputs` and the -n command-line option.  For example, to combine the stream of objects into a single object:\r\n\r\n    jq -n 'reduce inputs as $in (null; . + $in)'",
      "An alternative to slurping using the -s command-line option is to use the `inputs` filter. Like so:\r\n\r\n    jq -n '[inputs] | add'\r\n\r\nThis will produce an object with all the input objects combined.",
      "# Type I: single object\r\n\r\ncat objects.json \\\r\n | jq -ns '{ type: \"something\", subtype: \"specific\", content: (inputs | add) }'  "
    ],
    "utterance": "Combine a sequence where {\"a\": \"green\", \"b\": \"white\"} and {\"a\": \"red\", \"c\": \"purple\"} are read in sequence so that the output is a single object with keys from both and later values overriding earlier ones.",
    "expressions": [
      "add",
      "-s add",
      "[inputs] | add",
      "reduce inputs as $in (null; . + $in)",
      "reduce inputs as $in (.; . + $in)",
      "(inputs | add)"
    ],
    "data": [
      {
        "input": [
          {
            "a": "green",
            "b": "white"
          },
          {
            "a": "red",
            "c": "purple"
          }
        ],
        "output": {
          "a": "red",
          "b": "white",
          "c": "purple"
        }
      }
    ],
    "identifier": 34477547
  },
  {
    "context": [
      "I want to iterate through each dictionary in `images` array.",
      "jq -r '.images[]|\"image --\" + tostring' Contents.json"
    ],
    "utterance": "Output each object in the images array, prefixed with 'image --', as a single line per object.",
    "expressions": [
      ".images[] | \"image --\" + tostring",
      "-r '.images[]|\"image --\" + tostring'"
    ],
    "data": [
      {
        "input": {
          "images": [
            {
              "size": "29x29",
              "idiom": "iphone",
              "filename": "Icon-Small@2x.png",
              "scale": "2x"
            },
            {
              "size": "29x29",
              "idiom": "iphone",
              "filename": "Icon-Small@3x.png",
              "scale": "3x"
            }
          ],
          "info": {
            "version": 1,
            "author": "xcode"
          }
        },
        "output": [
          "image --{\"size\":\"29x29\",\"idiom\":\"iphone\",\"filename\":\"Icon-Small@2x.png\",\"scale\":\"2x\"}",
          "image --{\"size\":\"29x29\",\"idiom\":\"iphone\",\"filename\":\"Icon-Small@3x.png\",\"scale\":\"3x\"}"
        ]
      }
    ],
    "identifier": 34529156
  },
  {
    "context": [
      "What I was hoping to extract is a country for each of the records (some records have more than one country, which seems to be causing the problem). So my naive approach was to say:\r\n\r\n    .static_data.\"fullrecord_metadata\".addresses.address_name.country\r\n\r\nThis however gives me several errors (null has no keys, and cannot index array with string).",
      "So, could you suggest if I can actually extract the list of countries for each entry using jq?",
      "For each input top-level JSON entity, the following filter will recursively examine all the objects to see if they have a \"country\" key, and it will then report the distinct \"country\" values for that top-level entity:\r\n\r\n    jq -c '[.. | if type == \"object\" and has(\"country\") \r\n                 then .country\r\n                 else empty end] | unique'",
      "[.. | .country? // empty] | unique",
      "Here is a solution which uses a function to handle the variation in `.address_name`\r\n\r\n     def address_specs:\r\n        if type == \"array\" then .[].address_spec else .address_spec end\r\n     ;\r\n\r\n     .addresses | .address_name | [address_specs | .country] | unique"
    ],
    "utterance": "Extract a list of distinct country values for each top-level record, regardless of data structure variation.",
    "expressions": [
      "[.. | if type == \"object\" and has(\"country\") then .country else empty end] | unique",
      "[.. | .country? // empty] | unique",
      "def address_specs: if type == \"array\" then .[].address_spec else .address_spec end;\n.addresses | .address_name | [address_specs | .country] | unique"
    ],
    "data": [
      {
        "input": [
          {
            "addresses": {
              "@count": "1",
              "address_name": {
                "address_spec": {
                  "@addr_no": "1",
                  "full_address": "Tel Aviv Univ, Eitan Berglas Sch Econ, IL-69978 Tel Aviv, Israel",
                  "organizations": {
                    "@count": "2",
                    "organization": [
                      "Tel Aviv Univ",
                      {
                        "@pref": "Y",
                        "#text": "Tel Aviv University"
                      }
                    ]
                  },
                  "suborganizations": {
                    "@count": "1",
                    "suborganization": "Eitan Berglas Sch Econ"
                  },
                  "city": "Tel Aviv",
                  "country": "Israel",
                  "zip": {
                    "@location": "BC",
                    "#text": "IL-69978"
                  }
                }
              }
            },
            "category_info": {
              "headings": {
                "@count": "1",
                "heading": "Social Sciences"
              },
              "subjects": {
                "@count": "3",
                "subject": [
                  {
                    "@ascatype": "traditional",
                    "#text": "Economics"
                  },
                  {
                    "@ascatype": "extended",
                    "#text": "Business & Economics"
                  },
                  {
                    "@ascatype": "traditional",
                    "#text": "ECONOMICS"
                  }
                ]
              }
            }
          },
          {
            "addresses": {
              "@count": "1",
              "address_name": {
                "address_spec": {
                  "@addr_no": "1",
                  "full_address": "MIT, Cambridge, MA 02139 USA",
                  "organizations": {
                    "@count": "2",
                    "organization": [
                      "MIT",
                      {
                        "@pref": "Y",
                        "#text": "Massachusetts Institute of Technology (MIT)"
                      }
                    ]
                  },
                  "city": "Cambridge",
                  "state": "MA",
                  "country": "USA",
                  "zip": {
                    "@location": "AP",
                    "#text": "02139"
                  }
                }
              }
            },
            "category_info": {
              "headings": {
                "@count": "1",
                "heading": "Social Sciences"
              },
              "subjects": {
                "@count": "3",
                "subject": [
                  {
                    "@ascatype": "traditional",
                    "#text": "Economics"
                  },
                  {
                    "@ascatype": "extended",
                    "#text": "Business & Economics"
                  },
                  {
                    "@ascatype": "traditional",
                    "#text": "ECONOMICS"
                  }
                ]
              }
            }
          },
          {
            "addresses": {
              "@count": "2",
              "address_name": [
                {
                  "address_spec": {
                    "@addr_no": "1",
                    "full_address": "Univ Kentucky, Lexington, KY 40506 USA",
                    "organizations": {
                      "@count": "2",
                      "organization": [
                        "Univ Kentucky",
                        {
                          "@pref": "Y",
                          "#text": "University of Kentucky"
                        }
                      ]
                    },
                    "city": "Lexington",
                    "state": "KY",
                    "country": "USA",
                    "zip": {
                      "@location": "AP",
                      "#text": "40506"
                    }
                  }
                },
                {
                  "address_spec": {
                    "@addr_no": "2",
                    "full_address": "Univ Bonn, ZEI, D-5300 Bonn, Germany",
                    "organizations": {
                      "@count": "2",
                      "organization": [
                        "Univ Bonn",
                        {
                          "@pref": "Y",
                          "#text": "University of Bonn"
                        }
                      ]
                    },
                    "suborganizations": {
                      "@count": "1",
                      "suborganization": "ZEI"
                    },
                    "city": "Bonn",
                    "country": "Germany",
                    "zip": {
                      "@location": "BC",
                      "#text": "D-5300"
                    }
                  }
                }
              ]
            },
            "category_info": {
              "headings": {
                "@count": "1",
                "heading": "Social Sciences"
              },
              "subjects": {
                "@count": "3",
                "subject": [
                  {
                    "@ascatype": "traditional",
                    "#text": "Economics"
                  },
                  {
                    "@ascatype": "extended",
                    "#text": "Business & Economics"
                  },
                  {
                    "@ascatype": "traditional",
                    "#text": "ECONOMICS"
                  }
                ]
              }
            }
          }
        ],
        "output": [
          [
            "Israel"
          ],
          [
            "USA"
          ],
          [
            "Germany",
            "USA"
          ]
        ]
      }
    ],
    "identifier": 34367613
  },
  {
    "context": [
      "Is there a way to have jq keep processing what it can, while reporting the problems via stderr?",
      "With jq-1.5 I was able to do the following:",
      "cat example.log | jq --raw-input --raw-output '. as $raw | try fromjson catch $raw'",
      "cat example.log | jq --raw-input 'fromjson?'",
      "Silently skip non-json lines:",
      "Output non-json lines as unquoted strings:"
    ],
    "utterance": "Parse each line, returning parsed objects for valid lines and the original unparsed line for malformed ones.",
    "expressions": [
      ". as $raw | try fromjson catch $raw",
      "fromjson?"
    ],
    "data": [
      {
        "input": "{\n\"a\": 1}\n{invalid\n{\"b\": 2}\n",
        "output": [
          {
            "a": 1
          },
          "{invalid",
          {
            "b": 2
          }
        ]
      }
    ],
    "identifier": 34538789
  },
  {
    "context": [
      "datein=$(jq <\"r1.json\" \".results[$j].date\" | sed 's/\"//g')",
      "company=$(jq <\"r1.json\" \".results[$j].company\" | sed 's/,//g;s/\"//g;s/ //g')",
      "job=$(jq <\"r1.json\" \".results[$j].jobtitle\" | sed 's/,//g;s/\"//g;s/ //g')",
      "jq <\"r1.json\" \".results[$j]\" > ${dateout}_${company}_${job}.json",
      "for ((i=1;i<=kdr;i++))\n   do\n      for ((j=0;j<=24;j++))\n      do\n \tdatein=$(jq <\"r$i.json\" \".results[$j].date\" | sed 's/\"//g')\n \tdateout=$(date -d \"${datein}\" +\"%Y%m%d%H%M%S\")\n \tcompany=$(jq <\"r$i.json\" \".results[$j].company\" | sed 's/,//g;s/\"//g;s/ //g')\n \tjob=$(jq <\"r$i.json\" \".results[$j].jobtitle\" | sed 's/,//g;s/\"//g;s/ //g')\n \tjq <\"r$i.json\" \".results[$j]\" > ${dateout}_${company}_${job}.json\n      done\n   done"
    ],
    "utterance": "For each entry in the results array, extract the fields date, company, and jobtitle to construct a filename, and output that result entry to a separate file named with the format YYYYMMDDHHMMSS_company_jobtitle.json.",
    "expressions": [
      ".results[$j].date",
      ".results[$j].company",
      ".results[$j].jobtitle",
      ".results[$j]"
    ],
    "data": [
      {
        "input": {
          "radius": 25,
          "totalResults": 1329,
          "results": [
            {
              "jobtitle": "job1",
              "company": "company1",
              "date": "Sun, 01 Sep 2015 07:59:58 GMT"
            },
            {
              "jobtitle": "job2",
              "company": "company2",
              "date": "Sun, 02 Sep 2015 07:59:58 GMT"
            }
          ]
        },
        "output": [
          {
            "filename": "20150901075958_company1_job1.json",
            "content": {
              "jobtitle": "job1",
              "company": "company1",
              "date": "Sun, 01 Sep 2015 07:59:58 GMT"
            }
          },
          {
            "filename": "20150902075958_company2_job2.json",
            "content": {
              "jobtitle": "job2",
              "company": "company2",
              "date": "Sun, 02 Sep 2015 07:59:58 GMT"
            }
          }
        ]
      }
    ],
    "identifier": 34509937
  },
  {
    "context": [
      "What's the best way to read and convert a JSON field's decimal value to an ASCII character?  For instance, converting 107 to 'k'.",
      "$ jq -n '[107] | implode'",
      "'k'",
      "`implode` will work for both ASCII and non-ASCII decimal codes.  As illustrated here, it converts an array of admissible decimals to a UTF-8 string equivalent.",
      "Here's an example showing conversion:",
      "$ jq -n -c '{\"a\": [107, 108]} | .a |= implode'",
      "{\"a\":\"kl\"}"
    ],
    "utterance": "Convert a decimal value, such as 107, to its corresponding character.",
    "expressions": [
      "[107] | implode",
      ".a |= implode"
    ],
    "data": [
      {
        "input": [
          107
        ],
        "output": "k"
      },
      {
        "input": {
          "a": [
            107,
            108
          ]
        },
        "output": {
          "a": "kl"
        }
      }
    ],
    "identifier": 34561434
  },
  {
    "context": [
      "Does the `--slurp` option load the entire input in memory before processing it or has it been optimized somehow in order to avoid that?",
      "\"jq --slurp . FILE ....\" store the parsed input as an array in memory.",
      "This will often require more memory than the size of the input itself",
      "the `inputs` filter works very nicely with `reduce` and `foreach`."
    ],
    "utterance": "Find a way to process all input values as a stream without loading the entire content into memory.",
    "expressions": [
      "reduce inputs as $item (initial; <operation>)",
      "foreach inputs as $item (initial; <operation>; <extract>)"
    ],
    "identifier": 34778425
  },
  {
    "context": [
      "jq --arg v \"$PRJNAME\" '.dev.projects.\"$v\"' config.json ",
      "The jq program `.dev.projects.\"$v\"` in your example will literally try to find a key named `\"$v\"`. Try the following instead:",
      "jq --arg v \"$PRJNAME\" '.dev.projects[$v]' config.json "
    ],
    "utterance": "Retrieve the object for the project whose name is stored in the shell variable PRJNAME under dev.projects.",
    "expressions": [
      "jq --arg v \"$PRJNAME\" '.dev.projects[$v]' config.json"
    ],
    "data": [
      {
        "input": {
          "env": "dev",
          "dev": {
            "projects": {
              "prj1": {
                "dependencies": {},
                "description": ""
              }
            }
          }
        },
        "output": {
          "dependencies": {},
          "description": ""
        }
      }
    ],
    "identifier": 34745451
  },
  {
    "context": [
      "What I need is just to extract the numbers as a column:\r\n\r\n    80001\r\n\r\nor\r\n\r\n    12001\r\n    12002\r\n    12003\r\n    43120\r\n",
      "Rather than trying to use two invocations of `jq`, just use one.  Also, it&#39;s generally best to quote your `jq` filters when they&#39;re given on the command line.\r\n\r\nYou&#39;re dumping the values in the `ids` property, so:\r\n\r\n    jq \".ids[]\""
    ],
    "utterance": "Extract all numbers from the 'ids' property and output them as a column.",
    "expressions": [
      ".ids[]"
    ],
    "data": [
      {
        "input": {
          "ids": [
            80001
          ]
        },
        "output": 80001
      },
      {
        "input": {
          "ids": [
            12001,
            12002,
            12003,
            43120
          ]
        },
        "output": [
          12001,
          12002,
          12003,
          43120
        ]
      }
    ],
    "identifier": 34789412
  },
  {
    "context": [
      "I would like to use jq to remove all dictionaries within a JSON \"object\" (I used that term generally to refer to either an Array or a Dictionary) that \n\na) contain a key named \"delete_me\", AND\nb) where the key \"delete_me\" meets some predetermined condition (null, non-zero, true, etc)",
      "should yield, if the \"delete_me\" key is delete_if_this_is_null and the predetermined condition is delete_if_this_is_null == null:",
      "Here's the solution: ... walk( mapper(select((type == \"object\" and .delete_if_this_is_null == null) | not)) )",
      "def clean(condition):\n  if type == \"object\" then\n    if condition\n    then empty\n    else\n    with_entries(\n      if (.value|type) == \"object\" and (.value|condition)\n      then empty\n      else .value |= clean(condition)\n      end\n    )\n    end\n  elif type == \"array\" then\n    map(\n      if type == \"object\" and condition\n      then empty\n      else clean(condition)\n      end\n    )\n  else .\n  end\n;\n\nclean(\n  has(\"delete_if_this_is_null\") and (.delete_if_this_is_null == null)\n)"
    ],
    "utterance": "Remove all objects, at any depth, that have a key \"delete_if_this_is_null\" with value null.",
    "expressions": [
      "walk( mapper(select((type == \"object\" and .delete_if_this_is_null == null) | not)) )",
      "def clean(condition): if type == \"object\" then if condition then empty else with_entries( if (.value|type) == \"object\" and (.value|condition) then empty else .value |= clean(condition) end ) end elif type == \"array\" then map( if type == \"object\" and condition then empty else clean(condition) end ) else . end; clean(has(\"delete_if_this_is_null\") and (.delete_if_this_is_null == null))"
    ],
    "data": [
      {
        "input": {
          "a": {
            "foo": "bar"
          },
          "b": {
            "i": {
              "A": {
                "i": [
                  {
                    "foo": {},
                    "bar": {
                      "delete_if_this_is_null": false,
                      "an_array": [],
                      "another_array": [
                        {
                          "delete_if_this_is_null": null,
                          "foo": "bar"
                        }
                      ],
                      "etc": ""
                    },
                    "foo2": "s"
                  },
                  {
                    "foo": {
                      "an_array": [
                        {
                          "delete_if_this_is_null": "ok",
                          "foo": "bar",
                          "another_object": {
                            "a": 1
                          }
                        },
                        {
                          "delete_if_this_is_null": null,
                          "foo2": "bar2",
                          "another_object": {
                            "a": 1
                          },
                          "name": null
                        }
                      ],
                      "an_object": {
                        "delete_if_this_is_null": null,
                        "foo3": "bar3"
                      }
                    },
                    "zero": 0,
                    "b": "b"
                  }
                ]
              }
            }
          }
        },
        "output": {
          "a": {
            "foo": "bar"
          },
          "b": {
            "i": {
              "A": {
                "i": [
                  {
                    "foo": {},
                    "bar": {
                      "delete_if_this_is_null": false,
                      "an_array": [],
                      "another_array": [],
                      "etc": ""
                    },
                    "foo2": "s"
                  },
                  {
                    "foo": {
                      "an_array": [
                        {
                          "delete_if_this_is_null": "ok",
                          "foo": "bar",
                          "another_object": {
                            "a": 1
                          }
                        }
                      ]
                    },
                    "zero": 0,
                    "b": "b"
                  }
                ]
              }
            }
          }
        }
      }
    ],
    "identifier": 34098002
  },
  {
    "context": [
      "using jq I want to add an incremental id field like that:\n\n    [\n        {\"data\":\"a\",\"id\":\"xx_1\"},\n        {\"data\":\"b\",\"id\":\"xx_2\"},\n        {\"data\":\"c\",\"id\":\"xx_3\"}\n    ]",
      "Here\u2019s one way:\n    to_entries | map( (.value.id = \"xx_\\(1+.key)\" ) | .value)",
      "Here\u2019s another method, which however requires jq 1.5:\n    def add_id(prefix):\n      [ foreach .[] as $o (0;\n          . + 1;\n          $o + {\"id\": (prefix + tostring) }) ];\n    add_id(\"xx_\")",
      "A third approach would be to use `transpose`:\n    def add_id(prefix):\n      [ .,  [ range(0;length) | {\"id\": (prefix + tostring) } ] ]\n      | transpose | map(add);",
      "[\n  foreach .[] as $e (\n     0\n   ; .+1\n   ; $e + {\"id\":\"xx_\\(.)\"}\n  )\n]",
      "reduce range(0,length) as $i (\n     .\n   ; .[$i].id = \"xx_\\($i+1)\"\n)",
      "[enumerate(.[]) | last + {id: \"xx_\\(first + 1)\"}]"
    ],
    "utterance": "Add an id field to each object in an array, incrementing from 1 with a 'xx_' prefix, so the first item gets id 'xx_1', the second 'xx_2', etc.",
    "expressions": [
      "to_entries | map( (.value.id = \"xx_\\(1+.key)\") | .value)",
      "[ foreach .[] as $e (0; .+1; $e + {\"id\":\"xx_\\(.)\"} ) ]",
      "reduce range(0,length) as $i (. ; .[$i].id = \"xx_\\($i+1)\")",
      "def add_id(prefix): [ foreach .[] as $o (0; . + 1; $o + {\"id\": (prefix + tostring) }) ]; add_id(\"xx_\")",
      "def add_id(prefix): [ .,  [ range(0;length) | {\"id\": (prefix + tostring) } ] ] | transpose | map(add);",
      "def enumerate(s): foreach s as $x (-1; .+1; [., $x]); [enumerate(.[]) | last + {id: \"xx_\\(first + 1)\"}]"
    ],
    "data": [
      {
        "input": [
          {
            "data": "a"
          },
          {
            "data": "b"
          },
          {
            "data": "c"
          }
        ],
        "output": [
          {
            "data": "a",
            "id": "xx_1"
          },
          {
            "data": "b",
            "id": "xx_2"
          },
          {
            "data": "c",
            "id": "xx_3"
          }
        ]
      }
    ],
    "identifier": 34510742
  },
  {
    "context": [
      "But if I have something like this:\r\n\r\n    X-RateLimit-Reset: 1452786798\r\n\r\nI get this error:\r\n\r\n&gt; parse error: Invalid numeric literal at line 1, column 9",
      "using the -R command-line option, e.g.\r\n\r\n    echo \"X-RateLimit-Reset: 1452786798\" | jq -R 'split(\":\")'",
      "Thus, if you know the value is going to be numeric:\r\n\r\n    echo \"X-RateLimit-Reset: 1452786798\" |\r\n      jq -Rc 'split(\":\") | {(.[0]) : (.[1]|tonumber)}'\r\n    {\"X-RateLimit-Reset\":1452786798}"
    ],
    "utterance": "Convert a colon-delimited key-value pair where the value is numeric into an object with the key as the property and the numeric value as its value.",
    "expressions": [
      "split(\":\") | {(.[0]) : (.[1]|tonumber)}"
    ],
    "data": [
      {
        "input": "X-RateLimit-Reset: 1452786798",
        "output": {
          "X-RateLimit-Reset": 1452786798
        }
      }
    ],
    "identifier": 34794007
  },
  {
    "context": [
      "I have the following in a file (which I will call \"myfile\"): [{ \"id\": 123, \"name\": \"John\", \"aux\": [{ \"abc\": \"random\", \"def\": \"I want this\" }], \"blah\": 23.11 }]",
      "I could parse it if the file did not have the first `[` and last `]` as follows:\n$ cat myfile | jq -r '.aux[] | .def'\nI want this",
      "but with the `[` and `]` I get:\n$ cat myfile | jq -r '.aux[] | .def'\njq: error: Cannot index array with string",
      "How can I deal with the `[` and `]` using jq?",
      "It should be:\n    jq '[].aux[].def' file.json\n'.[]' iterates over the outer array, '.aux[]' then iterates over the the 'aux' array of every node and '.def' prints their '.def' property.",
      "If you want to get rid of the double quotes pass `-r` (`--raw`) to `jq`:\n    jq -r '.[].aux[].def' file.json"
    ],
    "utterance": "Extract all def values from aux objects within each element of the top-level array, with raw output.",
    "expressions": [
      ".[].aux[].def",
      ".[].aux[].def | @text",
      ".[].aux[] | .def"
    ],
    "data": [
      {
        "input": [
          {
            "id": 123,
            "name": "John",
            "aux": [
              {
                "abc": "random",
                "def": "I want this"
              }
            ],
            "blah": 23.11
          }
        ],
        "output": [
          "I want this"
        ]
      }
    ],
    "identifier": 34543829
  },
  {
    "context": [
      "Is there another way to read `jq`'s output line by line, or window by window, without having the terminal spammed with the full JSON object?",
      "Use the `jq -C` (colorize) option before paginating it with a pager like `more -r` or `less -r`.",
      "cat report.json | jq . -C | more",
      "cat report.json | jq . -C | less -r"
    ],
    "utterance": "View output one window at a time with color using a pager such as less or more.",
    "expressions": [
      "jq . -C | less -r",
      "jq . -C | more"
    ],
    "data": [
      {
        "input": {
          "hello": "world"
        }
      }
    ],
    "identifier": 34839073
  },
  {
    "context": [
      "echo \"{}\" | jq -scaM --unbuffered  | jq",
      "Using a more recent version (available via github):",
      "$ echo \"{}\" | jq -scaM --unbuffered | jq",
      "[",
      "  {}",
      "]"
    ],
    "utterance": "Read the output produced by a prior stream-combining operation using a subsequent query.",
    "expressions": [
      "jq -scaM --unbuffered",
      "jq"
    ],
    "data": [
      {
        "input": "{}",
        "output": [
          {}
        ]
      }
    ],
    "identifier": 34867088
  },
  {
    "context": [
      "First of all, `.foo.bar` is just shorthand syntax for `.[\"foo\"][\"bar\"]`. Use the latter for non-alphanumeric values such as `api-client`.",
      "Secondly, you should never compose jq scripts by interpolating shell variables into them. Instead, pass values to them using --arg.",
      "You should probably be doing this:",
      "${JQ} --arg project \"$PROJECT\" -r '.projects[$project]' ${CACHE}"
    ],
    "utterance": "Select a project by name using a value stored in a variable that may contain hyphens.",
    "expressions": [
      ".projects[$project]"
    ],
    "data": [
      {
        "input": {
          "projects": {
            "api-client": {
              "status": "false",
              "when": "19-01-2016 12:54:47"
            },
            "api-admin": {
              "status": "false",
              "when": "19-01-2016 12:54:47"
            },
            "myweb": {
              "status": "false",
              "when": "19-01-2016 12:54:47"
            }
          }
        },
        "output": {
          "status": "false",
          "when": "19-01-2016 12:54:47"
        }
      }
    ],
    "identifier": 34880288
  },
  {
    "context": [
      "How do I parse a json array of objects to a bash array with those objects as strings?",
      "get_json_array | jq -c '.[]' | while read object; do",
      "readarray -t conversations < <(get_json_array | jq -c '.[]')",
      "json=$(jq -c \".my_key[]\"  ./my-file.json)"
    ],
    "utterance": "Convert an array of objects so each element is a compact object string suitable for assignment to a bash array element.",
    "expressions": [
      ".[]",
      "-c .[]"
    ],
    "identifier": 35005893
  },
  {
    "context": [
      "I have a linux jq command \r\n\r\n     jq -r &#39;.&quot;FOO-BAR&quot;[] | .foo+ &quot; &quot; + .bar[]&#39;\r\n\r\nWhat would be equivalent of this in Windows shell syntax?",
      "The double-quotes in the original (i.e., the interior double-quotes) must be escaped, as discussed in the [Windows section of the jq FAQ][1].\r\n\r\nThus your example would become:\r\n\r\n    jq -r &quot;.\\&quot;FOO-BAR\\&quot;[] | .foo+ \\&quot; \\&quot; + .bar[]&quot;"
    ],
    "utterance": "For each element in the FOO-BAR array, output the value of foo concatenated with a space and each value in the bar array.",
    "expressions": [
      ".\"FOO-BAR\"[] | .foo+ \" \" + .bar[]"
    ],
    "identifier": 35029593
  },
  {
    "context": [
      "How can I keep all the objects for which the `.b` property is one of `[1, 7]` (in reality the list is much longer so I don't want to do `select(.b == 1 or .b == 7)`).",
      "A more efficient alternative would be `select(any($value == $collection[]; .))`",
      "`[1, 7] as $whitelist | select(any(.b == $whitelist[]; .))`",
      "`jq --argjson whitelist '[2, 7]' 'select(any(.b == $whitelist[]; .))'`",
      "jq --argjson w '[1,7]' '. as $in | select($w | index($in.b))'",
      "jq '. as $in | select([1, 7] | index($in.b))'",
      "jq --argjson w '[1,7]' 'select( .b | IN($w[]) )'"
    ],
    "utterance": "Select all objects where the property b is one of 1 or 7.",
    "expressions": [
      "[1, 7] as $whitelist | select(any(.b == $whitelist[]; .))",
      "select(any(.b == [1, 7][]; .))",
      ". as $in | select([1, 7] | index($in.b))",
      "select(.b | IN(1; 7))",
      "select(.b | IN([1, 7][]))"
    ],
    "data": [
      {
        "input": [
          {
            "a": 0,
            "b": 1
          },
          {
            "a": 2,
            "b": 2
          },
          {
            "a": 7,
            "b": null
          },
          {
            "a": 3,
            "b": 7
          }
        ],
        "output": [
          {
            "a": 0,
            "b": 1
          },
          {
            "a": 3,
            "b": 7
          }
        ]
      }
    ],
    "identifier": 34878915
  },
  {
    "context": [
      "I have a JSON formatted stream, full of objects. Each object looks like this:\n    {\n      \"object\": \"alpha\",\n      \"attributes\": [ ... ]\n    }\n\nI'd like to get data out as:\n    alpha,A,a,1271129046.9144535\n    alpha,B,b,6738889338.63777\n    alpha,C,c,214918692.38456276\n    alpha,D,d,140222346.75136077\n    alpha,E,e,2085635554.8128803",
      "You just need to collect an array of the values you want to write out and pass it in to the filter.  You could do this:\n\n    $ jq -r '.attributes[] as $attr | [.object, $attr.type, $attr.description, $attr.value] | @csv' input.json",
      "Slightly briefer than the accepted answer:\n\n    jq -r '[.object] + (.attributes[] | [.type, .description, .value]) | @csv'\n",
      "If you don't want the quotation marks, then one possibility would be:\n\n    jq -r '\"\\(.object),\" + (.attributes[] | \"\\(.type),\\(.description),\\(.value)\")'"
    ],
    "utterance": "Extract lines combining the object's name with each attribute's type, description, and value, formatted as comma-separated values.",
    "expressions": [
      ".attributes[] as $attr | [.object, $attr.type, $attr.description, $attr.value] | @csv",
      "[.object] + (.attributes[] | [.type, .description, .value]) | @csv",
      "\"\\(.object),\" + (.attributes[] | \"\\(.type),\\(.description),\\(.value)\")"
    ],
    "data": [
      {
        "input": {
          "object": "alpha",
          "attributes": [
            {
              "type": "A",
              "description": "a",
              "value": 1271129046.9144535
            },
            {
              "type": "B",
              "description": "b",
              "value": 6738889338.63777
            },
            {
              "type": "C",
              "description": "c",
              "value": 214918692.38456276
            },
            {
              "type": "D",
              "description": "d",
              "value": 140222346.75136077
            },
            {
              "type": "E",
              "description": "e",
              "value": 2085635554.8128803
            }
          ]
        },
        "output": [
          "\"alpha\",\"A\",\"a\",1271129046.9144535",
          "\"alpha\",\"B\",\"b\",6738889338.63777",
          "\"alpha\",\"C\",\"c\",214918692.38456276",
          "\"alpha\",\"D\",\"d\",140222346.75136077",
          "\"alpha\",\"E\",\"e\",2085635554.8128803"
        ]
      }
    ],
    "identifier": 34958101
  },
  {
    "context": [
      "I need to loop through the keywords to get the identifiers (not sure if I'm using the right terminology here). Seems pretty simple, but because the keywords are all named different, I don't know how to handle that.",
      "The original tag for this question was `jq` so here is a `jq` solution: \r\n\r\n    .[] | keys[]",
      "$ jq '.[] | keys[]' input.json\r\n \r\n    \"identifier1\"\r\n    \"identifier2\""
    ],
    "utterance": "List all identifier keys that are nested within each top-level key, regardless of the top-level key name.",
    "expressions": [
      ".[] | keys[]"
    ],
    "data": [
      {
        "input": {
          "keyword1": {
            "identifier1": 16
          },
          "keyword2": {
            "identifier2": 16
          }
        },
        "output": [
          "identifier1",
          "identifier2"
        ]
      }
    ],
    "identifier": 35086391
  },
  {
    "context": [
      "I have a variable, X, in a bash script that has a value like `asw|uduu|sssdd`. How can I convert it to a JSON array using jq?",
      "A second variable, Y, has a value like `A:1|B:1|C:1`. How can I convert it to a JSON object using jq?",
      "echo 'asw|uduu|sssdd' | jq -Rc 'split(\"|\")'",
      "produces:\n    [\"asw\",\"uduu\",\"sssdd\"]",
      "echo 'A:1|B:1|C:1' |\n jq -Rc 'split(\"|\") | map( split(\":\") | {(.[0]): .[1]} ) | add'",
      "produces: {\"A\":\"1\",\"B\":\"1\",\"C\":\"1\"}"
    ],
    "utterance": "Convert the string 'A:1|B:1|C:1' to an object with keys A, B, and C and corresponding values 1, 1, and 1.",
    "expressions": [
      "split(\"|\") | map( split(\":\") | {(.[0]): .[1]} ) | add"
    ],
    "data": [
      {
        "input": "A:1|B:1|C:1",
        "output": {
          "A": "1",
          "B": "1",
          "C": "1"
        }
      }
    ],
    "identifier": 35137058
  },
  {
    "context": [
      "I\u0018d want to update any url matching the pattern:\r\n\r\n    http://otherdomain.com.*filenameB.*\r\n\r\nto some fixed string such as:\r\n\r\n    http://yetanotherdomain.com/new/path/to/filenameC.tar.gz",
      "Any ideas on how to get the path of the key that has a value matching a regex?  And after that, how to update the key with some new string value?  If there are multiple matches, all should be updated with the same new value.",
      "map( if .url | test(\"http://otherdomain.com.*filenameB.*\")\n     then .url |= sub(  \"http://otherdomain.com.*filenameB.*\"; \n           \"http://yetanotherdomain.com/new/path/to/filenameC.tar.gz\")\n     else .\n     end)",
      "\"http://otherdomain.com.*filenameB.*\"                      as $from\n| \"http://yetanotherdomain.com/new/path/to/filenameC.tar.gz\" as $to\n\n| reduce (tostream | select(length == 2 and .[0][-1] == \"url\")) as $p (\n      .\n    ; setpath($p[0]; $p[1] | sub($from; $to))\n  )"
    ],
    "utterance": "Replace every url whose value matches 'http://otherdomain.com.*filenameB.*' with 'http://yetanotherdomain.com/new/path/to/filenameC.tar.gz'.",
    "expressions": [
      "map( if .url | test(\"http://otherdomain.com.*filenameB.*\")\n     then .url |= sub(\"http://otherdomain.com.*filenameB.*\"; \"http://yetanotherdomain.com/new/path/to/filenameC.tar.gz\")\n     else .\n     end)",
      "\"http://otherdomain.com.*filenameB.*\" as $from\n| \"http://yetanotherdomain.com/new/path/to/filenameC.tar.gz\" as $to\n| reduce (tostream | select(length == 2 and .[0][-1] == \"url\")) as $p (\n    .\n  ; setpath($p[0]; $p[1] | sub($from; $to))\n)"
    ],
    "data": [
      {
        "input": [
          {
            "type": "A",
            "name": "name 1",
            "url": "http://domain.com/path/to/filenameA.zip"
          },
          {
            "type": "B",
            "name": "name 2",
            "url": "http://domain.com/otherpath/to/filenameB.zip"
          },
          {
            "type": "C",
            "name": "name 3",
            "url": "http://otherdomain.com/otherpath/to/filenameB.zip"
          }
        ],
        "output": [
          {
            "type": "A",
            "name": "name 1",
            "url": "http://domain.com/path/to/filenameA.zip"
          },
          {
            "type": "B",
            "name": "name 2",
            "url": "http://domain.com/otherpath/to/filenameB.zip"
          },
          {
            "type": "C",
            "name": "name 3",
            "url": "http://yetanotherdomain.com/new/path/to/filenameC.tar.gz"
          }
        ]
      }
    ],
    "identifier": 35086206
  },
  {
    "context": [
      "It should return if all three conditions are true:\r\n\r\n    Key == \"service\" && Value == \"widget\"\r\n    Key == \"environment\" && Value == \"production\"\r\n    Key == \"customer_prefix\" && Value == \"widget_xyz\"",
      "Here at any rate is a solution that uses a helper function which does have an inner function.\r\n\r\n    # Does \"obj\" match any of the objects in the input array?\r\n    def anymatch(obj):\r\n      # Do all the key-value pairs in obj also occur in the input?\r\n      def match(obj):\r\n        . as $in\r\n        | obj as $o\r\n        | all( $o|keys[]; $in[.] == $o[.]);\r\n      any(.[]; match(obj));\r\n\r\n    .TagDescriptions[]\r\n    | select( .Tags\r\n            | (anymatch({\"Key\":\"customer_prefix\", \"Value\": \"widget_xyz\"})\r\n               and anymatch({\"Key\":\"environment\", \"Value\": \"production\"})\r\n               and anymatch({\"Key\":\"service\", \"Value\": \"widget\"} ) ))\r\n    | .LoadBalancerName",
      "The `Tags` array are perfect for creating an object out of for easy access.  Make things easy on yourself and do so.  Then access to the values would be significantly easier.  Then you could easily test to see if your conditions are satisfied.\r\n\r\n    .TagDescriptions[] | select(\r\n        .Tags | from_entries | [\r\n            .service == \"widget\",\r\n            .environment == \"production\",\r\n            .customer_prefix == \"widget_xyz\"\r\n        ] | all\r\n    ).LoadBalancerName"
    ],
    "utterance": "Return the LoadBalancerName for each element where the Tags array contains objects with Key and Value pairs: Key == \"service\" and Value == \"widget\", Key == \"environment\" and Value == \"production\", and Key == \"customer_prefix\" and Value == \"widget_xyz\".",
    "expressions": [
      "def anymatch(obj):\n  def match(obj):\n    . as $in | obj as $o | all($o|keys[]; $in[.] == $o[.]);\n  any(.[]; match(obj));\n\n.TagDescriptions[]\n| select( .Tags\n        | (anymatch({\"Key\":\"customer_prefix\", \"Value\": \"widget_xyz\"})\n           and anymatch({\"Key\":\"environment\", \"Value\": \"production\"})\n           and anymatch({\"Key\":\"service\", \"Value\": \"widget\"} ) ))\n| .LoadBalancerName",
      ".TagDescriptions[] | select(\n    .Tags | from_entries | [\n        .service == \"widget\",\n        .environment == \"production\",\n        .customer_prefix == \"widget_xyz\"\n    ] | all\n).LoadBalancerName"
    ],
    "data": [
      {
        "input": {
          "TagDescriptions": [
            {
              "Tags": [
                {
                  "Value": "production",
                  "Key": "environment"
                },
                {
                  "Value": "widget",
                  "Key": "service"
                },
                {
                  "Value": "widget_xyz",
                  "Key": "customer_prefix"
                },
                {
                  "Value": "widget_xyz-widget-production",
                  "Key": "Name"
                }
              ],
              "LoadBalancerName": "widget-xyz-widget-prod"
            },
            {
              "Tags": [
                {
                  "Value": "widget-xyz-stage-widget-ConsulStack-DKJSADKJS",
                  "Key": "aws:cloudformation:stack-name"
                },
                {
                  "Value": "stage",
                  "Key": "environment"
                },
                {
                  "Value": "arn:aws:cloudformation:us-east-1:123456789:stack/widget-xyz-stage-widget-ConsulStack-DKJSADKJS/d46ad520-92e7-11e5-a975-500150b34c7c",
                  "Key": "aws:cloudformation:stack-id"
                },
                {
                  "Value": "widget",
                  "Key": "service"
                },
                {
                  "Value": "widget_xyz",
                  "Key": "customer_prefix"
                },
                {
                  "Value": "ELB",
                  "Key": "aws:cloudformation:logical-id"
                },
                {
                  "Value": "widget_xyz-widget-stage",
                  "Key": "Name"
                }
              ],
              "LoadBalancerName": "widget-xyz-ELB-SDKJSDKJSADKJAS"
            },
            {
              "Tags": [
                {
                  "Value": "widget-xyz-prod-widget-ConsulStack-DLFJEIJNWDKD",
                  "Key": "aws:cloudformation:stack-name"
                },
                {
                  "Value": "prod",
                  "Key": "environment"
                },
                {
                  "Value": "arn:aws:cloudformation:us-east-1:123456789:stack/widget-xyz-prod-widget-ConsulStack-DLFJEIJNWDKD/ab2292f0-9398-11e5-b0f6-50d501114c2c",
                  "Key": "aws:cloudformation:stack-id"
                },
                {
                  "Value": "widget",
                  "Key": "service"
                },
                {
                  "Value": "widget_xyz",
                  "Key": "customer_prefix"
                },
                {
                  "Value": "ELB",
                  "Key": "aws:cloudformation:logical-id"
                },
                {
                  "Value": "widget_xyz-widget-prod",
                  "Key": "Name"
                }
              ],
              "LoadBalancerName": "widget-xyz-ELB-SKDJSKDJSAKDJAS"
            }
          ]
        },
        "output": "widget-xyz-widget-prod"
      }
    ],
    "identifier": 33973816
  },
  {
    "context": [
      "But the csv output I need should look like this (with or without quotation marks):",
      "\"Page1\",15001,\"0.0-1000.0\",7,1000.0-2000.0,1005,\"2000.0-*&\",8907",
      "\"Page2\",340,\"0.0-1000.0\",23,1000.0-2000.0,261,\"2000.0-*&\",18",
      "@csv only works on a flat array, so you could add '| .[] | @csv' to your pipeline."
    ],
    "utterance": "Convert each Elasticsearch aggregation label's statistics and range buckets into a single CSV-formatted line containing the page name, document count, each range, and its document count.",
    "expressions": [
      ".aggregations[\"byLabels\"].buckets | map([.key, .doc_count] + (.byRange.buckets | to_entries | map([.key, .value.doc_count]) | flatten)) | .[] | @csv"
    ],
    "data": [
      {
        "input": {
          "took": 3,
          "timed_out": false,
          "_shards": {
            "total": 5,
            "successful": 5,
            "failed": 0
          },
          "hits": {
            "total": 51632,
            "max_score": 0.0,
            "hits": []
          },
          "aggregations": {
            "byLabels": {
              "doc_count_error_upper_bound": 0,
              "sum_other_doc_count": 2478,
              "buckets": [
                {
                  "key": "Page 1",
                  "doc_count": 15001,
                  "byRange": {
                    "buckets": {
                      "0.0-1000.0": {
                        "from": 0.0,
                        "from_as_string": "0.0",
                        "to": 1000.0,
                        "to_as_string": "1000.0",
                        "doc_count": 7
                      },
                      "1000.0-2000.0": {
                        "from": 1000.0,
                        "from_as_string": "1000.0",
                        "to": 2000.0,
                        "to_as_string": "2000.0",
                        "doc_count": 1005
                      },
                      "2000.0-*": {
                        "from": 2000.0,
                        "from_as_string": "2000.0",
                        "doc_count": 8907
                      }
                    }
                  }
                },
                {
                  "key": "Page 2",
                  "doc_count": 340,
                  "byRange": {
                    "buckets": {
                      "0.0-1000.0": {
                        "from": 0.0,
                        "from_as_string": "0.0",
                        "to": 1000.0,
                        "to_as_string": "1000.0",
                        "doc_count": 23
                      },
                      "1000.0-2000.0": {
                        "from": 1000.0,
                        "from_as_string": "1000.0",
                        "to": 2000.0,
                        "to_as_string": "2000.0",
                        "doc_count": 261
                      },
                      "2000.0-*": {
                        "from": 2000.0,
                        "from_as_string": "2000.0",
                        "doc_count": 18
                      }
                    }
                  }
                }
              ]
            }
          }
        },
        "output": [
          "\"Page 1\",15001,\"0.0-1000.0\",7,\"1000.0-2000.0\",1005,\"2000.0-*\",8907",
          "\"Page 2\",340,\"0.0-1000.0\",23,\"1000.0-2000.0\",261,\"2000.0-*\",18"
        ]
      }
    ],
    "identifier": 35131859
  },
  {
    "context": [
      "I can get all the `login` names with this : `cat members | jq '.[].login'` but I have not been able to crack the syntax to get both the `login` _and_ `id`?",
      "You can use `jq '.[] | .login, .id'` to obtain each login followed by its id.",
      "Use `{ login, id }`, which is a shorthand for `{ login: .login, id: .id }`.",
      "$ cat example.ndjson | jq -c '{ login, id }'                \n{\"login\":\"dmaxfield\",\"id\":7449977}\n{\"login\":\"eiffel\",\"id\":7449978}",
      "For jq >= v1.7\n\nThe builtin function pick is useful to slice objects (i.e. projection).\n\n$ cat example.ndjson | jq -c 'pick(.login, .id)'\n{\"login\":\"dmaxfield\",\"id\":7449977}\n{\"login\":\"eiffel\",\"id\":7449978}",
      "jq -r '.[] | \"\\(.login) \\(.id)\"'",
      "jq -r '\"\\(.login) \\(.id)\"'"
    ],
    "utterance": "Extract both login and id fields from each object in a newline-delimited file.",
    "expressions": [
      "{ login, id }",
      "pick(.login, .id)",
      ".[] | { login, id }",
      ".[] | pick(.login, .id)",
      ".[] | \"\\(.login) \\(.id)\"",
      "\"\\(.login) \\(.id)\""
    ],
    "data": [
      {
        "input": [
          {
            "login": "dmaxfield",
            "id": 7449977,
            "foo": true
          },
          {
            "login": "eiffel",
            "id": 7449978,
            "foo": false
          }
        ],
        "output": [
          {
            "login": "dmaxfield",
            "id": 7449977
          },
          {
            "login": "eiffel",
            "id": 7449978
          }
        ]
      },
      {
        "input": {
          "login": "dmaxfield",
          "id": 7449977,
          "foo": true
        }
      }
    ],
    "identifier": 34834519
  },
  {
    "context": [
      "I have this vms.json",
      "[{\"name\": \"jms1\", \"port1\": 24000, \"port2\": 25000, \"port3\": 26000}, {\"name\": \"jms2\", \"port1\": 24001, \"port2\": 25000, \"port3\": 26001}]",
      "I have a port_script.sh  which takes [name] [port1] [port2] [port3]  as numbered arguments.",
      "To get the values your script needs, just refer to them with the `.foo` syntax. For example, running `jq -r '.[].name'` over the given input file would produce the following output:\n    jms1\n    jms2",
      "Similarly, you can refer to all of them:\n\n`jq -r '.[] | .name, .port1, .port2, .port3'`",
      "And, if you'd like them in an array as in the example above, just wrap them in brackets:\n\n`jq -r -c '.[] | [.name, .port1, .port2, .port3]'`",
      "$ jq -r '.[] | \"port_script.sh \\\"\\(.name)\\\" \\\"\\(.port1)\\\" \\\"\\(.port2)\\\" \\\"\\(.port3)\\\"\"'",
      "Or better yet perhaps:\n$ jq -r --arg command port_script.sh '.[] | $command + \" \\\"\\(.name)\\\" \\\"\\(.port1)\\\" \\\"\\(.port2)\\\" \\\"\\(.port3)\\\"\"'",
      "jq --raw-output '.[] | [.name, .port1, .port2, .port3] | @tsv'"
    ],
    "utterance": "Extract name, port1, port2, and port3 from each object in the array as a list suitable for passing as arguments to a shell script.",
    "expressions": [
      ".[] | [.name, .port1, .port2, .port3]",
      "-r -c '.[] | [.name, .port1, .port2, .port3]'",
      "-r '.[] | \"port_script.sh \\\"\\(.name)\\\" \\\"\\(.port1)\\\" \\\"\\(.port2)\\\" \\\"\\(.port3)\\\"\"'",
      "--raw-output '.[] | [.name, .port1, .port2, .port3] | @tsv'"
    ],
    "data": [
      {
        "input": [
          {
            "name": "jms1",
            "port1": 24000,
            "port2": 25000,
            "port3": 26000
          },
          {
            "name": "jms2",
            "port1": 24001,
            "port2": 25000,
            "port3": 26001
          }
        ],
        "output": [
          [
            "jms1",
            24000,
            25000,
            26000
          ],
          [
            "jms2",
            24001,
            25000,
            26001
          ]
        ]
      }
    ],
    "identifier": 35141521
  }
]