[
  {
    "context": [
      "echo $json | jq -r '. | keys[]' | \\",
      "while read tag ; do",
      "value=$(echo \"$json\" | jq -r \".[\\\"$tag\\\"]\")",
      "A possible workaround is to use process substitution:",
      "while read tag; do",
      "...",
      "done < <(jq -r '. | keys[]' <<< \"$1\")"
    ],
    "utterance": "Retrieve all top-level keys from an object, one per line.",
    "expressions": [
      ". | keys[]",
      "keys[]"
    ],
    "data": [
      {
        "input": {
          "Name": "*FOO*",
          "Cost Center": "XX111"
        },
        "output": [
          "Name",
          "Cost Center"
        ]
      }
    ],
    "identifier": 47446387
  },
  {
    "context": [
      "jq -r -c '[.field1,.field2] | \"\\(.[0]), \\(.[1])\"'",
      "{ \"field1\": 1, \"field2\": 2 }",
      "1, 2",
      "I'd guess you intended the jq filter to be:\n\n    [.field1,.field2] | \"\\(.[0]), \\(.[1])\""
    ],
    "utterance": "Extract field1 and field2 values and output them as a comma-separated string in the order field1, field2.",
    "expressions": [
      "[.field1,.field2] | \"\\(.[0]), \\(.[1])\""
    ],
    "data": [
      {
        "input": {
          "field1": 1,
          "field2": 2
        },
        "output": "1, 2"
      }
    ],
    "identifier": 47525421
  },
  {
    "context": [
      "What I would like it to do is to take whatever value I would like to find, like in the example `!CVE-2014-0160` (like a search engine) and be able to recursively go through the entire JSON dataset and have the same end result as my code atm.",
      "In fact, the following, which is just a small variation of what you already have, should meet the requirements as I currently understand them:",
      "..\n| ((.opts.vulns | index(\"!CVE-2014-0160\"))? // empty) as $ix\n| [.ip_str, .isp, .timestamp, .opts.vulns[$ix]]\n| @csv",
      "If you want to parameterize the string to search for, replace it by (for example) $string in the jq program, and invoke jq like so",
      "jq -r --arg string \"!CVE-2014-0160\" -f program.jq shodan_data.json"
    ],
    "utterance": "Find all objects containing the value '!CVE-2014-0160' anywhere in .opts.vulns, and output .ip_str, .isp, .timestamp, and the matched vuln as CSV.",
    "expressions": [
      ".. | ((.opts.vulns | index(\"!CVE-2014-0160\"))? // empty) as $ix | [.ip_str, .isp, .timestamp, .opts.vulns[$ix]] | @csv",
      ".. | ((.opts.vulns | index($string))? // empty) as $ix | [.ip_str, .isp, .timestamp, .opts.vulns[$ix]] | @csv"
    ],
    "data": [
      {
        "input": {
          "ip_str": "196.196.216.13",
          "isp": "Fiber Grid Inc",
          "timestamp": "2017-08-29T06:57:22.546423",
          "opts": {
            "vulns": [
              "!CVE-2014-0160"
            ]
          }
        },
        "output": "\"196.196.216.13\",\"Fiber Grid Inc\",\"2017-08-29T06:57:22.546423\",\"!CVE-2014-0160\""
      }
    ],
    "identifier": 47445219
  },
  {
    "context": [
      "I am new to jq and cannot work out how to get idle value from the above json. By using jq command to retrieve json. How do I get idle value using jq?",
      "$ jq -M '.sysstat.hosts[0].statistics[0].\"cpu-load\"[0].idle' data.json",
      ".. | .idle? // empty",
      ".sysstat.hosts[].statistics[] | .[\"cpu-load\"][] | .idle"
    ],
    "utterance": "Extract the value of the 'idle' field for the first CPU load entry in the statistics of the first host.",
    "expressions": [
      ".sysstat.hosts[0].statistics[0].\"cpu-load\"[0].idle",
      ".sysstat.hosts[].statistics[] | .[\"cpu-load\"][] | .idle",
      ".. | .idle? // empty"
    ],
    "data": [
      {
        "input": {
          "sysstat": {
            "hosts": [
              {
                "nodename": "localhost.localdomain",
                "sysname": "Linux",
                "release": "4.13.13-200.fc26.x86_64",
                "machine": "x86_64",
                "number-of-cpus": 2,
                "date": "24/11/17",
                "statistics": [
                  {
                    "timestamp": "00:00:45",
                    "cpu-load": [
                      {
                        "cpu": "0",
                        "usr": 5.08,
                        "nice": 0.03,
                        "sys": 1.31,
                        "iowait": 0.07,
                        "irq": 0.73,
                        "soft": 0.09,
                        "steal": 0,
                        "guest": 0,
                        "gnice": 0,
                        "idle": 92.69
                      }
                    ]
                  }
                ]
              }
            ]
          }
        },
        "output": 92.69
      }
    ],
    "identifier": 47464756
  },
  {
    "context": [
      "This works quite fine so far but special characters (like \u00fc, \u00e4, \u00f6, \u00dc, \u00c4, \u00d6) are not kept in the jq output.",
      "As you can see the characters \u00dc\u00c4\u00d6 are not recognized and are saved as ???.",
      "This is how I use jq in PowerShell:",
      "$json = Get-Content .\\json.txt -Encoding UTF8",
      "$jsonSorted = $json | .\\jq-win64.exe --sort-keys '.'",
      "Set-Content jsonSorted.txt -Value $jsonSorted -Encoding UTF8",
      "I had to set [System.Console]::OutputEncoding=[System.Text.Encoding]::UTF8 in PowerShell and then it works as expected. That's actually the only thing I had to do."
    ],
    "utterance": "Sort all fields alphabetically and ensure that special characters such as \u00dc, \u00c4, and \u00d6 are preserved in the output.",
    "expressions": [
      ".",
      "--sort-keys ."
    ],
    "data": [
      {
        "input": {
          "sha": "18879fb99367924cd76d402e841155bf73c8afb3",
          "commit": {
            "author": {
              "name": "John Doe \u00dc\u00c4\u00d6",
              "email": "john@example.com",
              "date": "2017-11-23T07:51:22Z"
            }
          }
        },
        "output": {
          "commit": {
            "author": {
              "date": "2017-11-23T07:51:22Z",
              "email": "john@example.com",
              "name": "John Doe \u00dc\u00c4\u00d6"
            }
          },
          "sha": "18879fb99367924cd76d402e841155bf73c8afb3"
        }
      }
    ],
    "identifier": 47527290
  },
  {
    "context": [
      "I need to retrieve all top values from this JSON, i.e. \"string1\", \"string2\" and \"string3\".",
      "If you want them as a stream in the original order, use `keys_unsorted[]`;",
      "if you want them to be sorted first, use `keys[]`."
    ],
    "utterance": "List all top-level property names from an object, such as string1, string2, and string3.",
    "expressions": [
      "keys_unsorted[]",
      "keys[]"
    ],
    "data": [
      {
        "input": {
          "string1": [
            {
              "spec1": "spec1value",
              "spec2": "spec2value"
            }
          ],
          "string2": [
            {
              "spec1": "spec1value",
              "spec2": "spec2value"
            }
          ],
          "string3": [
            {
              "spec1": "spec1value",
              "spec2": "spec2value"
            }
          ]
        },
        "output": [
          "string1",
          "string2",
          "string3"
        ]
      }
    ],
    "identifier": 47542110
  },
  {
    "context": [
      "I need to do some CURLs from which I&#39;m building one output JSON. This is how I managed to perform a merge using a function:",
      "It seems when JSON inside `$DATA` is big enough then I&#39;m getting `Argument list too long` error. Is it possible (in a nice way) to treat JSON to merge as a single argument here?",
      "You could use process substitution and `--slurpfile` option to solve your issue:",
      "MERGEDENTRY=$(echo \"$SOURCE\" | jq --slurpfile json <(printf '%s\\n' \"$ADDITIONALJSONDATA\") '. += $json[0]' | tr -d '\\r\\n')",
      "MERGEDENTRY=$(jq --slurpfile json <(printf '%s\\n' \"$ADDITIONALJSONDATA\") '. += $json[0]' <<< \"$SOURCE\" | tr -d '\\r\\n')",
      "MERGEDENTRY=$(jq -c --arg TYPE \"$DATATYPE\" --slurpfile A <(printf '%s\\n' \"$DATA\") '\n  . += {($TYPE): $A[0]}' <<< \"$SOURCE\")",
      "(We need to use `$A[0]` here because \"slurping\" puts $DATA into an array.)"
    ],
    "utterance": "Merge the current object with another, adding a key whose name is given by a variable and whose value is the contents of another large JSON object, handling long arguments safely.",
    "expressions": [
      "jq --slurpfile json <(printf '%s\\n' \"$ADDITIONALJSONDATA\") '. += $json[0]' <<< \"$SOURCE\"",
      "jq -c --arg TYPE \"$DATATYPE\" --slurpfile A <(printf '%s\\n' \"$DATA\") '. += {($TYPE): $A[0]}' <<< \"$SOURCE\""
    ],
    "identifier": 47442344
  },
  {
    "context": [
      "I need to transform a JSON, which can either have 1 value or 2. So it can be:",
      "And the output I need is this:",
      "{'input': {'text': 'aaa'}}",
      "or",
      "{'input': {'text': 'aaa'},'context': 'something'}}",
      "jq solution:",
      "jq '.params.context as $ctx \n    | {input: {text:.form.textinput1}} \n    + (if ($ctx | length) > 0 then {context:$ctx} else {} end)' file.json",
      ".params.context as $ctx - assign .params.context value into variable $ctx",
      "if ($ctx | length) > 0 - check if $ctx is not empty",
      "jq has two basic conditionals: if ... then ... else ... end and A // B.  In your case, the first suffices:",
      "{'input': {'text': .form.textinput1}}\n+ (.params.context | if . == '' then null else {'context':.} end)"
    ],
    "utterance": "Return an object with key 'input' containing the value of 'form.textinput1', and if 'params.context' is not empty, include it as a top-level 'context' field.",
    "expressions": [
      ".params.context as $ctx | {input: {text: .form.textinput1}} + (if ($ctx | length) > 0 then {context:$ctx} else {} end)",
      "{input: {text: .form.textinput1}} + (.params.context | if . == \"\" then null else {context: .} end)"
    ],
    "data": [
      {
        "input": {
          "form": {
            "textinput1": "aaa"
          },
          "params": {
            "context": ""
          }
        },
        "output": {
          "input": {
            "text": "aaa"
          }
        }
      },
      {
        "input": {
          "form": {
            "textinput1": "aaa"
          },
          "params": {
            "context": "something"
          }
        },
        "output": {
          "input": {
            "text": "aaa"
          },
          "context": "something"
        }
      }
    ],
    "identifier": 47528282
  },
  {
    "context": [
      "I tried to see if jq would help but I don't see any option to tell it to encode newline character.",
      "You could use jq with the -s and -R options, e.g.",
      "jq -sR .",
      "Result:",
      "\"a\\nb\\n\""
    ],
    "utterance": "Convert a multi-line text file into a single JSON string while preserving newline characters.",
    "expressions": [
      "jq -sR ."
    ],
    "identifier": 47577690
  },
  {
    "context": [
      "I want to convert it into something like the following using **`jq`**:",
      "{\n  \"anger\": 0.012,\n  \"disgust\": 0.002,\n  \"fear\": 0.14,\n  \"joy\": 0.42\n}",
      "cat result.json | jq '.[] | { (.tone_id): .score }'",
      "With **`reduce`** function:",
      "jq 'reduce .[] as $o ({}; .[$o[\"tone_id\"]] = $o[\"score\"])' result.json",
      "A single-invocation one-liner:",
      "jq 'map( {(.tone_id): .score} ) | add'",
      "You can use `from_entries`:",
      "jq '[.[] | {key: .tone_id, value: .score}] | from_entries' tmp.json",
      "# or jq 'map({key: .tone_id, value: .score}) | from_entries' tmp.json"
    ],
    "utterance": "Transform an array of objects so that each object's tone_id becomes a key and its score the corresponding value, producing a single object with all tone_id:score pairs.",
    "expressions": [
      "reduce .[] as $o ({}; .[$o[\"tone_id\"]] = $o[\"score\"])",
      "map({(.tone_id): .score}) | add",
      "[.[] | {key: .tone_id, value: .score}] | from_entries",
      "map({key: .tone_id, value: .score}) | from_entries"
    ],
    "data": [
      {
        "input": [
          {
            "tone_id": "anger",
            "score": 0.012,
            "tone_name": "Anger"
          },
          {
            "tone_id": "disgust",
            "score": 0.002,
            "tone_name": "Disgust"
          },
          {
            "tone_id": "fear",
            "score": 0.14,
            "tone_name": "Fear"
          },
          {
            "tone_id": "joy",
            "score": 0.42,
            "tone_name": "Joy"
          }
        ],
        "output": {
          "anger": 0.012,
          "disgust": 0.002,
          "fear": 0.14,
          "joy": 0.42
        }
      }
    ],
    "identifier": 47551333
  },
  {
    "context": [
      "But `jq '.. | keys'` returns `jq: error at <stdin> string has no keys`.",
      "Just ignore keys when they are absent for some values in JSON:\n\n    jq '.. | keys?'",
      "Ignore non-objects when inspecting for key names:\n```\njq -r '.. | if type == \"object\" then to_entries[] | .key else empty end' \"${LOCALAPPDATA}/Google/Chrome/User Data/default/Bookmarks\" | sort --uniq\nbookmark_bar\nchecksum\nchildren\ndate_added\ndate_modified\nguid\nid\nname\nother\nroots\nsynced\ntype\nurl\nversion\n```"
    ],
    "utterance": "List all key names at any nesting level, excluding non-objects.",
    "expressions": [
      ".. | keys?",
      ".. | if type == \"object\" then to_entries[] | .key else empty end"
    ],
    "identifier": 47591829
  },
  {
    "context": [
      "BUT when I pipe the output of JQ to a text file (I want a formatted version to be saved for readability, not the plain unformatted json)I get an error",
      "If you want `jq` to format the same JSON it got as input, pass `.` as the script for it to run:",
      "curl -H \"Accept: application/json\" https://icanhazdadjoke.com/ | jq . > file.txt"
    ],
    "utterance": "Format the retrieved object for readability and save it to a file, preserving all fields unchanged.",
    "expressions": [
      "jq ."
    ],
    "data": [
      {
        "input": {
          "id": "5wAIRfaaUvc",
          "joke": "What do you do when a blonde throws a grenade at you? Pull the pin and throw it back.",
          "status": 200
        },
        "output": "{\n  \"id\": \"5wAIRfaaUvc\",\n  \"joke\": \"What do you do when a blonde throws a grenade at you? Pull the pin and throw it back.\",\n  \"status\": 200\n}"
      }
    ],
    "identifier": 47578328
  },
  {
    "context": [
      "I am looking for a solution where array element name doesn't need to be specified, so I can use that expression for every of similar content file.",
      "Here is a possible solution ... $ jq -Mn '\n    reduce inputs as $i ({}; \n     reduce ($i|keys[]) as $k (.; .[$k] += $i[$k])) \n  | del(.links)\n' file1.json file2.json file3.json",
      "The following is essentially the same as @jq170727's solution, but packages the key abstraction into a function ...",
      "def buckets(stream): reduce stream as $x ({};\n  reduce ($x|keys_unsorted[]) as $key (.;\n    .[$key] += [$x[$key]] ) );",
      "With this in place, the solution becomes simply:\n\n    buckets(inputs) | map_values(add) | del(.links)",
      "OP asked:\n\n> what do I need to do if I don't want to add the total_entries from each of the file, I would like to take the value from the first file only",
      "The following modification of the above program will use the first-encountered value for `total_entries`:\n\n    buckets(inputs)\n    | . as $buckets\n    | map_values(add)\n    | del(.links) + {total_entries: $buckets[\"total_entries\"][0]}"
    ],
    "utterance": "Merge multiple input files with common object structure so that all array-valued fields are concatenated and scalar fields retain the value from the first file; do not hardcode the array element name.",
    "expressions": [
      "jq -Mn 'reduce inputs as $i ({}; reduce ($i|keys[]) as $k (.; .[$k] += $i[$k])) | del(.links)' file1.json file2.json file3.json",
      "def buckets(stream): reduce stream as $x ({}; reduce ($x|keys_unsorted[]) as $key (.; .[$key] += [$x[$key]] ) ); buckets(inputs) | map_values(add) | del(.links)",
      "def buckets(stream): reduce stream as $x ({}; reduce ($x|keys_unsorted[]) as $key (.; .[$key] += [$x[$key]] ) ); buckets(inputs) | . as $buckets | map_values(add) | del(.links) + {total_entries: $buckets[\"total_entries\"][0]}"
    ],
    "data": [
      {
        "input": [
          {
            "projects": [
              {
                "id": 15658857,
                "code": "111"
              },
              {
                "id": 15623456,
                "code": "122"
              }
            ],
            "total_entries": 1391,
            "links": {
              "next": "https://api.xxx.com/projects?page=12&per_page=100",
              "last": "https://api.xxx.com/projects?page=14&per_page=100"
            }
          },
          {
            "projects": [
              {
                "id": 15658857,
                "code": "211"
              }
            ],
            "total_entries": 2391,
            "links": {
              "next": "https://api.xxx.com/projects?page=22&per_page=100",
              "last": "https://api.xxx.com/projects?page=24&per_page=100"
            }
          },
          {
            "projects": [
              {
                "id": 15658857,
                "code": "311"
              },
              {
                "id": 15623456,
                "code": "322"
              },
              {
                "id": 13438719,
                "code": "333"
              }
            ],
            "total_entries": 3391,
            "links": {
              "next": "https://api.xxx.com/projects?page=32&per_page=100",
              "last": "https://api.xxx.com/projects?page=34&per_page=100"
            }
          }
        ],
        "output": {
          "projects": [
            {
              "id": 15658857,
              "code": "111"
            },
            {
              "id": 15623456,
              "code": "122"
            },
            {
              "id": 15658857,
              "code": "211"
            },
            {
              "id": 15658857,
              "code": "311"
            },
            {
              "id": 15623456,
              "code": "322"
            },
            {
              "id": 13438719,
              "code": "333"
            }
          ],
          "total_entries": 1391
        }
      }
    ],
    "identifier": 47461167
  },
  {
    "context": [
      "I am using `jq` to parse the stuff I want from this JSON file, and appending it to a text file. This text file also ends up having the strings like `\\n`, `\\t` instead of newline, tabs, etc. I want the text file to have actual meaning of these control characters.",
      "For example, for the string `\"I\\nam\\na\\ngood\\nboy\"`, I want my file to have:\n    I\n    am\n    a\n    good\n    boy",
      "Use the `-r` argument to tell `jq` to use raw strings for its output.",
      "jq -r . <<EOF\n\"I\\nam\\na\\ngood\\nboy\"\nEOF",
      "...emits the precise output:\n    I\n    am\n    a\n    good\n    boy"
    ],
    "utterance": "Convert string values containing escaped control character sequences like \\n into output with real newlines when extracting values.",
    "expressions": [
      "jq -r ."
    ],
    "data": [
      {
        "input": "\"I\\nam\\na\\ngood\\nboy\"",
        "output": "I\nam\na\ngood\nboy"
      }
    ],
    "identifier": 47585325
  },
  {
    "context": [
      "One (not so hot) option would be to redirect STDERR to /dev/null:",
      "jq  -r '.results[].uri' 2> /dev/null",
      "Use `curl --fail` to only continue on to run the `jq` command if the `curl` succeeds:"
    ],
    "utterance": "Hide all error messages produced when processing invalid or unexpected input.",
    "expressions": [
      "jq -r '.results[].uri' 2> /dev/null"
    ],
    "identifier": 47641412
  },
  {
    "context": [
      "I want to break this array into smaller array files using jq.",
      "jq IO is rather primitive, so I&#39;d suggest starting with:\r\n\r\n    def chunks(n):\r\n      def c: .[0:n], (if length &gt; n then .[n:]|c else empty end);\r\n      c;\r\n  \r\n    chunks(5)",
      "jq -c --argjson n 5 &#39;recurse(.[$n:]; length &gt; 0) | .[0:$n]&#39; foo.json"
    ],
    "utterance": "Split an array of objects into subarrays of 5 elements each.",
    "expressions": [
      "def chunks(n): def c: .[0:n], (if length > n then .[n:]|c else empty end); c; chunks(5)",
      "recurse(.[5:]; length > 0) | .[0:5]"
    ],
    "data": [
      {
        "input": [
          {
            "foo": 1
          },
          {
            "foo": 2
          },
          {
            "foo": 3
          },
          {
            "foo": 4
          },
          {
            "foo": 5
          },
          {
            "foo": 6
          },
          {
            "foo": 7
          },
          {
            "foo": 8
          },
          {
            "foo": 9
          },
          {
            "foo": 10
          },
          {
            "foo": 11
          },
          {
            "foo": 12
          },
          {
            "foo": 13
          },
          {
            "foo": 14
          },
          {
            "foo": 15
          }
        ],
        "output": [
          [
            {
              "foo": 1
            },
            {
              "foo": 2
            },
            {
              "foo": 3
            },
            {
              "foo": 4
            },
            {
              "foo": 5
            }
          ],
          [
            {
              "foo": 6
            },
            {
              "foo": 7
            },
            {
              "foo": 8
            },
            {
              "foo": 9
            },
            {
              "foo": 10
            }
          ],
          [
            {
              "foo": 11
            },
            {
              "foo": 12
            },
            {
              "foo": 13
            },
            {
              "foo": 14
            },
            {
              "foo": 15
            }
          ]
        ]
      }
    ],
    "identifier": 47564278
  },
  {
    "context": [
      "If I run the following command (to change `oldvalue` to `somevalue`):\n\n    jq '.someparent[\"somechild\"] = \"somevalue\" \"$aDirection/package.json\"'\n\nIt is successfully changed.",
      "However, if I give a variable instead of `someValue`:\n\n     aVar=\"anotherValue\"\n     jq '.someparent[\"somechild\"] = \"$aVar\" \"$aDirection/package.json\"'\n\nIt is not working.",
      "In your case the right filter is just\n\n    .someparent[\"somechild\"] = $aVar",
      "to use a shell variable in to the `jq`, you need to use the `--arg` field. Putting together both of the options. The first variable after `--arg` is used in the context of `jq` and the one following it is the actual shell variable.\n\naVar=\"anotherValue\"\njq --arg aVar \"$aVar\" '.someparent[\"somechild\"] = $aVar' \"$aDirection/package.json\""
    ],
    "utterance": "Set the value of 'somechild' under 'someparent' to the value of a shell variable named aVar in the input file.",
    "expressions": [
      ".someparent[\"somechild\"] = $aVar"
    ],
    "data": [
      {
        "input": {
          "someparent": {
            "somechild": "oldvalue"
          }
        },
        "output": {
          "someparent": {
            "somechild": "anotherValue"
          }
        }
      }
    ],
    "identifier": 47638471
  },
  {
    "context": [
      "I have a JSON which looks like this:\r\n\r\n    {\r\n    \t\"lorem\": \"ipsum\",\r\n    \t\"dolor\": \"sid\",\r\n    \t\"data\": {\r\n    \t\t\"key1\": \"value1\",\r\n    \t\t\"key2\": \"value2\"\r\n    \t}\r\n    }\r\n\r\nand I want an output which is ini like where I only need the content of 'data' (which is always flat, no branches). The output should look like this:\r\n\r\n    key1=value1\r\n    key2=value2\r\n",
      "jq -r '.data | to_entries[] | \"\\(.key)=\\(.value)\"' input.json",
      "The output:\r\n\r\n    key1=value1\r\n    key2=value2\r\n"
    ],
    "utterance": "Extract all key-value pairs from the 'data' object and format them as key=value, one per line.",
    "expressions": [
      ".data | to_entries[] | \"\u0000(.key)=\u0000(.value)\""
    ],
    "data": [
      {
        "input": {
          "lorem": "ipsum",
          "dolor": "sid",
          "data": {
            "key1": "value1",
            "key2": "value2"
          }
        },
        "output": "key1=value1\nkey2=value2"
      }
    ],
    "identifier": 47676527
  },
  {
    "context": [
      "I have two variables in shell script, each one contains a JSON data.",
      "I wanted to merge these using command jq '.' $var1 $var2",
      "jq -n \"$var1 + $var2\"",
      "jq -s add <(echo \"$var1\") <(echo \"$var2\")",
      "jq -s add \"$var1 $var2\"",
      "env.var1 + env.var2"
    ],
    "utterance": "Merge two shell variables containing separate objects so their key-value pairs are combined in a single object.",
    "expressions": [
      "jq -n \"$var1 + $var2\"",
      "jq -s add <(echo \"$var1\") <(echo \"$var2\")",
      "jq -s add \"$var1 $var2\"",
      "jq -n 'env.var1 + env.var2'"
    ],
    "data": [
      {
        "input": [
          {
            "key1": "value1"
          },
          {
            "key2": "value2"
          }
        ],
        "output": {
          "key1": "value1",
          "key2": "value2"
        }
      }
    ],
    "identifier": 47693714
  },
  {
    "context": [
      "I have a number of series of data that belongs to a specific version that I want to calculate the difference between. The base data will always be an array with two elements containing the data serie's values. The number of values within each series can vary, i.e. the number of \"valX\" values is not constant.",
      "The result should give all values \"ver1\"-\"ver2\".",
      "And I want a result like this or fairly similar:\n\n    [\n      {\n        \"id\": \"name1\",\n        \"val1\": \"-0.42\",\n        \"val2\": \"1.00\",\n        \"val3\": \"-1.39\",\n        \"val4\": \"0.01\"\n      },\n      {\n        \"id\": \"name2\",\n        \"val1\": \"-2.20\",\n        \"val2\": \"-0.45\",\n        \"val3\": \"1.05\"\n      }\n    ]",
      "key functionality required, which I take to be finding the \"difference\" between two objects with the same `id` and whose other keys are numerical strings.",
      "# $a - $b\ndef minus($a; $b):\n  def round(n):\n    (if . < 0 then -1 else 1 end) as $s\n    | $s*10*.*n\n    | if (floor % 10) > 4 then (.+5) else . end\n    | ./10 | floor/n | .*$s;\n\n  def m($k): ($a[$k]|tonumber) - ($b[$k]|tonumber) | round(100);\n  reduce ($a|keys_unsorted[]) as $k ({};\n    if $k == \"id\" then .id = $a[\"id\"]\n    else .[$k] = m($k)\n    end);\n\n  minus(s2; s1)",
      "map(.series) | transpose | map(minus(.[1]; .[0]))"
    ],
    "utterance": "Compute the difference for each value key between series with the same id in two versioned datasets, returning an array of objects keyed by id and value differences.",
    "expressions": [
      "def minus($a; $b):\n  def round(n):\n    (if . < 0 then -1 else 1 end) as $s\n    | $s*10*.*n\n    | if (floor % 10) > 4 then (.+5) else . end\n    | ./10 | floor/n | .*$s;\n  def m($k): ($a[$k]|tonumber) - ($b[$k]|tonumber) | round(100);\n  reduce ($a|keys_unsorted[]) as $k ({};\n    if $k == \"id\" then .id = $a[\"id\"]\n    else .[$k] = m($k)\n    end);\nmap(.series) | transpose | map(minus(.[1]; .[0]))"
    ],
    "data": [
      {
        "input": [
          {
            "version": "ver1",
            "series": [
              {
                "id": "name1",
                "val1": "0.77",
                "val2": "1.34",
                "val3": "7.89",
                "val4": "6.00"
              },
              {
                "id": "name2",
                "val1": "0.34",
                "val2": "1.00",
                "val3": "12.15"
              }
            ]
          },
          {
            "version": "ver2",
            "series": [
              {
                "id": "name1",
                "val1": "0.35",
                "val2": "2.34",
                "val3": "6.50",
                "val4": "6.01"
              },
              {
                "id": "name2",
                "val1": "2.54",
                "val2": "0.55",
                "val3": "13.20"
              }
            ]
          }
        ],
        "output": [
          {
            "id": "name1",
            "val1": -0.42,
            "val2": 1,
            "val3": -1.39,
            "val4": 0.01
          },
          {
            "id": "name2",
            "val1": 2.2,
            "val2": -0.45,
            "val3": 1.05
          }
        ]
      }
    ],
    "identifier": 47573491
  },
  {
    "context": [
      "This is how my input file looks like:\r\n\r\n    [\r\n      {\r\n        \"ConfigType\": \"ABC\",\r\n        \"Prop1\": 3,\r\n        \"Prop2\": 30\r\n      },\r\n      {\r\n        \"ConfigType\": \"XYZ\",\r\n        \"Prop3\": \"Hello\",\r\n        \"Prop4\": \"World\",\r\n        \"Prop5\": \"Application\"\r\n      }\r\n    ]",
      "How do I execute `aws dynamodb put-item --table-name \"xxx\" --item <<array's element>>`?",
      "mapfile -t configArr < <(jq -c '.[]'  < app-cnfg.json)",
      "while IFS= read -r config; do\n    aws dynamodb put-item --table-name \"xxx\" --item \"$config\"\ndone< <(jq -c '.[]' < app-cnfg.json)",
      "jq -c '.[]' app-cnfg.json \\\n    | xargs -L 1 aws dynamodb put-item --table-name \"xxx\" --item",
      "jq -c --raw-output0 '.[]' app-cnfg.json \\\n    | xargs -0 -n1 aws dynamodb put-item --table-name \"xxx\" --item",
      "jq -j '.[] | tostring + \"\\u0000\"' app-cnfg.json \\\n    | xargs -0 -n1 aws dynamodb put-item --table-name \"xxx\" --item"
    ],
    "utterance": "Output each array element from the input that contains objects so each can be passed as an argument to a shell command with the compact (single-line) representation.",
    "expressions": [
      ".[]",
      "-c '.[]'",
      "-c --raw-output0 '.[]'",
      "-j '.[] | tostring + \"\\u0000\"'"
    ],
    "data": [
      {
        "input": [
          {
            "ConfigType": "ABC",
            "Prop1": 3,
            "Prop2": 30
          },
          {
            "ConfigType": "XYZ",
            "Prop3": "Hello",
            "Prop4": "World",
            "Prop5": "Application"
          }
        ],
        "output": [
          "{\"ConfigType\":\"ABC\",\"Prop1\":3,\"Prop2\":30}",
          "{\"ConfigType\":\"XYZ\",\"Prop3\":\"Hello\",\"Prop4\":\"World\",\"Prop5\":\"Application\"}"
        ]
      }
    ],
    "identifier": 47660015
  },
  {
    "context": [
      "jq -r '.users[] | [.username, .email, .total running apps, .api-mock-app, .flogo, .ipaas, .nodejs-app] | @csv'",
      "You need to quote your column names, especially since they contain spaces and dashes. However you need to escape the quotes for bash:",
      "jq --raw-output '.users[] | [.username, .email, .\"total running apps\", .\"api-mock-app\", .\"flogo\", .\"ipaas\", .\"nodejs-app\"] | @csv'"
    ],
    "utterance": "Output each user's username, email, total running apps, api-mock-app, flogo, ipaas, and nodejs-app as CSV rows, supporting keys with spaces and dashes in their names.",
    "expressions": [
      ".users[] | [.username, .email, .\"total running apps\", .\"api-mock-app\", .\"flogo\", .\"ipaas\", .\"nodejs-app\"] | @csv"
    ],
    "data": [
      {
        "input": {
          "users": [
            {
              "username": "jack",
              "email": "jack@somewhere.com",
              "total running apps": "1",
              "api-mock-app": "0",
              "flogo": "1",
              "ipaas": "0",
              "nodejs-app": "0"
            },
            {
              "username": "jill",
              "email": "jill@somewhere.com",
              "total running apps": "1",
              "api-mock-app": "0",
              "flogo": "1",
              "ipaas": "0",
              "nodejs-app": "0"
            }
          ]
        },
        "output": [
          "\"jack\",\"jack@somewhere.com\",\"1\",\"0\",\"1\",\"0\",\"0\"",
          "\"jill\",\"jill@somewhere.com\",\"1\",\"0\",\"1\",\"0\",\"0\""
        ]
      }
    ],
    "identifier": 47715234
  },
  {
    "context": [
      "So, when i try to do left join on these two data, it will returns (dat3.ndjson)\r\n\r\n    [{state: a, code: aa},{state: a, code: aa, count: 1}]\r\n    [{state: b, code: bb},{state: b, code: bb, count: 2}]\r\n    [{state: c, code: cc},null]",
      "The purpose is to connect this 'count' information to map data, so usually I will first assign all items a count = 0 in dat1.ndjson",
      "If i use the following command to add all values together, it will return an error because of that null in the third line.",
      "I am looking for a better way to do this. I think there might be some ways by using 'ndjson-cli', 'jq' or 'awk' and 'sed' and etc.",
      "Here is a solution ...",
      "join(.state) | .count //= 0",
      "The output from the above one-liner will be the NDJSON:\r\n\r\n    {\"state\":\"a\",\"code\":\"aa\",\"count\":1}\r\n    {\"state\":\"b\",\"code\":\"bb\",\"count\":2}\r\n    {\"state\":\"c\",\"code\":\"cc\",\"count\":0}"
    ],
    "utterance": "For each map item, add the count value from a second data file where available, or set count to 0 if missing, matching by state.",
    "expressions": [
      "join(.state) | .count //= 0"
    ],
    "data": [
      {
        "input": [
          [
            {
              "state": "a",
              "code": "aa"
            },
            {
              "state": "b",
              "code": "bb"
            },
            {
              "state": "c",
              "code": "cc"
            }
          ],
          [
            {
              "state": "a",
              "code": "aa",
              "count": 1
            },
            {
              "state": "b",
              "code": "bb",
              "count": 2
            }
          ]
        ],
        "output": [
          {
            "state": "a",
            "code": "aa",
            "count": 1
          },
          {
            "state": "b",
            "code": "bb",
            "count": 2
          },
          {
            "state": "c",
            "code": "cc",
            "count": 0
          }
        ]
      }
    ],
    "identifier": 47725394
  },
  {
    "context": [
      "and then I want all the objects that satisfy the filter to populate a new file chinadata.json",
      "i am trying to filter the objects with     \"region\": \"China\"",
      "cat fulldata.json | jq 'select(.submitter.user_fields.region == \"China\")' > chinadata.json",
      "Your query applies to objects, not to arrays.",
      "So a simple workaround is to wrap your query in a call to map(). This results in success.",
      "If you would rather just skip the anomalous records, consider using jq's (only) postfix ? operator, e.g. map( select(.submitter?.user_fields?.region? == \"China\") )"
    ],
    "utterance": "Select all objects whose submitter's user_fields region is \"China\" and output them as a new array, skipping objects where the path does not exist.",
    "expressions": [
      "map(select(.submitter?.user_fields?.region? == \"China\"))"
    ],
    "data": [
      {
        "input": [
          {
            "submitter": {
              "user_fields": {
                "region": "Colombia"
              }
            }
          },
          {
            "submitter": {
              "user_fields": {
                "region": "China"
              }
            }
          },
          {
            "submitter": {
              "user_fields": {
                "region": "China"
              }
            }
          },
          {
            "submitter": {
              "user_fields": {
                "region": "Mexico"
              }
            }
          },
          {
            "submitter": {
              "user_fields": {
                "region": "Canada"
              }
            }
          }
        ],
        "output": [
          {
            "submitter": {
              "user_fields": {
                "region": "China"
              }
            }
          },
          {
            "submitter": {
              "user_fields": {
                "region": "China"
              }
            }
          }
        ]
      }
    ],
    "identifier": 47764356
  },
  {
    "context": [
      "I want to filter data based on particular department and save it in a different json file. From above data suppose I want to filter all the data whose department is 'abc' and save it in some new json file.",
      "jq 'map(select(.department == \"abc\")) ' yourfile.json",
      "jq --arg key department --arg value abc \\\n'.[] | select(.[$key] == $value)' input_file.json > output_file.json"
    ],
    "utterance": "Filter objects whose department equals 'abc'.",
    "expressions": [
      "map(select(.department == \"abc\"))",
      ".[] | select(.department == \"abc\")",
      "jq --arg key department --arg value abc '.[] | select(.[$key] == $value)'"
    ],
    "data": [
      {
        "input": [
          {
            "name": "alon",
            "department": "abc",
            "id": "ss12sd"
          },
          {
            "name": "kate",
            "department": "xyz",
            "id": "ajsj3"
          },
          {
            "name": "sam",
            "department": "abc",
            "id": "xx1d2"
          }
        ],
        "output": [
          {
            "name": "alon",
            "department": "abc",
            "id": "ss12sd"
          },
          {
            "name": "sam",
            "department": "abc",
            "id": "xx1d2"
          }
        ]
      }
    ],
    "identifier": 47779110
  },
  {
    "context": [
      "I am trying to figure out a way to use a `conf.json` file where I may have a _key : value_ such as\n\n    SAMPLE_RATE : 1000\n\nand I would like to same use this value to change the preprocessor directives defines in an Arduino Sketch such as (`test.ino`)",
      "VALUE=$(jq .SAMPLE_RATE conf.json)"
    ],
    "utterance": "Extract the value associated with key SAMPLE_RATE from the file conf.json.",
    "expressions": [
      ".SAMPLE_RATE",
      "jq .SAMPLE_RATE conf.json"
    ],
    "data": [
      {
        "input": {
          "SAMPLE_RATE": 1000
        },
        "output": 1000
      }
    ],
    "identifier": 47833632
  },
  {
    "context": [
      "I'm trying to figure out how to use [jq][1] to load the content of one json file into the hash of another file.",
      "should be inserted into this file at the hash dashboard",
      "jq --slurpfile annot annot.json '.dashboard |= $annot[0]' dashb.json",
      "jq -s '.[0] as $fragment | .[1] | (.dashboard |= $fragment)' fragment.json dashboard.json"
    ],
    "utterance": "Replace the 'dashboard' key in a file with the contents of another file.",
    "expressions": [
      "jq --slurpfile annot annot.json '.dashboard |= $annot[0]' dashb.json",
      "jq -s '.[0] as $fragment | .[1] | (.dashboard |= $fragment)' fragment.json dashboard.json"
    ],
    "data": [
      {
        "input": {
          "annot.json": {
            "annotations": {},
            "rows": [
              {},
              {}
            ]
          },
          "dashb.json": {
            "dashboard": {},
            "overwrite": true,
            "message": "new commit"
          }
        },
        "output": {
          "dashboard": {
            "annotations": {},
            "rows": [
              {},
              {}
            ]
          },
          "overwrite": true,
          "message": "new commit"
        }
      }
    ],
    "identifier": 47822596
  },
  {
    "context": [
      "I want to write a jq query to firstly select the Hash element in the Array at `.profiles.auto_scaler` whose Array of Hashes at `.auto_scaler_group_options.tags` contains Hashes containing a \":key\" key whose value *contains* \"fonzi\" and a \":value\" key whose value is *exactly* `true` and then return the value of the key `dns_name`.",
      "In brief, yes.",
      ".profiles.auto_scaler[]\n| .dns_name as $name\n| .auto_scaler_group_options\n| select( any(.[\":tags\"][];\n             (.[\":key\"] | index(\"fonzi\")) and (.[\":value\"] == \"true\")) )\n| $name",
      "The output of the above is:\n\n    \"fonz1\"",
      "If your jq does not have `any`, you could (in this particular case) get away without it by replacing the `select` expression above with:\n\n select( .[\":tags\"][]\n         | (.[\":key\"] | index(\"fonzi\")) and (.[\":value\"] == \"true\") )"
    ],
    "utterance": "Return the dns_name of the auto_scaler entry where one of the :tags has a :key containing \"fonzi\" and a :value exactly equal to \"true\".",
    "expressions": [
      ".profiles.auto_scaler[] | .dns_name as $name | .auto_scaler_group_options | select( any(.[\":tags\"][]; (.[\":key\"] | index(\"fonzi\")) and (.[\":value\"] == \"true\")) ) | $name",
      ".profiles.auto_scaler[] | .auto_scaler_group_options | select( .[\":tags\"][] | (.[\":key\"] | index(\"fonzi\")) and (.[\":value\"] == \"true\") ) | .dns_name"
    ],
    "data": [
      {
        "input": {
          "profiles": {
            "auto_scaler": [
              {
                "auto_scaler_group_name": "myasg0",
                "auto_scaler_group_options": {
                  ":availability_zones": [
                    "1a",
                    "1b",
                    "1c"
                  ],
                  ":max_size": 1,
                  ":min_size": 1,
                  ":subnets": [
                    "a",
                    "b",
                    "c"
                  ],
                  ":tags": [
                    {
                      ":key": "Name",
                      ":value": "app0"
                    },
                    {
                      ":key": "env",
                      ":value": "dev"
                    },
                    {
                      ":key": "role",
                      ":value": "app"
                    },
                    {
                      ":key": "domain",
                      ":value": "example.com"
                    },
                    {
                      ":key": "fonzi_app",
                      ":value": "true"
                    },
                    {
                      ":key": "vpc",
                      ":value": "nonprod"
                    }
                  ]
                },
                "dns_name": "fonz1"
              },
              {
                "auto_scaler_group_name": "myasg1",
                "auto_scaler_group_options": {
                  ":availability_zones": [
                    "1a",
                    "1b",
                    "1c"
                  ],
                  ":max_size": 1,
                  ":min_size": 1,
                  ":subnets": [
                    "a",
                    "b",
                    "c"
                  ],
                  ":tags": [
                    {
                      ":key": "Name",
                      ":value": "app1"
                    },
                    {
                      ":key": "env",
                      ":value": "dev"
                    },
                    {
                      ":key": "role",
                      ":value": "app"
                    },
                    {
                      ":key": "domain",
                      ":value": "example.com"
                    },
                    {
                      ":key": "bozo_app",
                      ":value": "true"
                    },
                    {
                      ":key": "vpc",
                      ":value": "nonprod"
                    }
                  ]
                },
                "dns_name": "bozo1"
              }
            ]
          }
        },
        "output": "fonz1"
      }
    ],
    "identifier": 47749719
  },
  {
    "context": [
      "Is there any difference between the two following expressions in `jq`?",
      "match(\"prefix.*if you do\";\"gmi\")",
      "match([\"prefix.*if you do\",\"gmi\"])",
      "They both return the expected data:",
      "Using either syntax `[regex,flags]` or `regex;flags` works as according to the manual:",
      "There was a time when multi-arity functions were not supported in jq. I believe that the duality that you describe is a legacy of those days. Any discrepancy would be a bug worthy of being reported."
    ],
    "utterance": "Check whether using match with match(\"prefix.*if you do\";\"gmi\") and match([\"prefix.*if you do\",\"gmi\"]) produces the same result.",
    "expressions": [
      "match(\"prefix.*if you do\";\"gmi\")",
      "match([\"prefix.*if you do\",\"gmi\"])"
    ],
    "data": [
      {
        "input": {
          "caveats": "The command has been installed with the prefix \"g\".\nIf you do not want the prefix, install using the \"with-default-names\"\noption.\n"
        }
      }
    ],
    "identifier": 47862242
  },
  {
    "context": [
      "I\u2019m trying to run the following command that reads JSON from a file and formats it with jq :",
      "jq -n -r --arg m $(<$1) '$m | fromjson | {records:[{value:.}]}'",
      "It produces the desired output when the input JSON does not contain spaces, such as {\"test\":\"helloworld\"} :",
      "However, for an input like {\"test\":\"hello world\"} it would give the following error:",
      "jq: error: syntax error, unexpected QQSTRING_START, expecting $end (Unix shell quoting issues?) at <top-level>, line 1:",
      "Change the --arg option to have the value within double quote:",
      "arg='{ \"test\": \"hello world\" }'",
      "jq -n -r --arg m \"$arg\" '$m | fromjson | {records:[{value:.}]}'"
    ],
    "utterance": "Wrap a value containing spaces in double quotes when passing it via --arg and access it for parsing and restructuring as {records:[{value:.}]}",
    "expressions": [
      "jq -n -r --arg m \"$arg\" '$m | fromjson | {records:[{value:.}]}'"
    ],
    "data": [
      {
        "input": {
          "test": "hello world"
        },
        "output": {
          "records": [
            {
              "value": {
                "test": "hello world"
              }
            }
          ]
        }
      }
    ],
    "identifier": 47775462
  },
  {
    "context": [
      "I want to disable all addons which are not \"rescheduler\", i.e. set `.enabled = false` for elements of array `.properties.orchestratorProfile.kubernetesConfig.addons[]` where `.name != \"rescheduler\"`.",
      "The expected outcome is:\n\n    {\n    \"apiVersion\": \"vlabs\",\n    \"properties\": {\n        \"orchestratorProfile\": {\n        ...\n            \"addons\": [\n            {\n                \"name\": \"tiller\",\n                \"enabled\": false\n            },\n            {\n                \"name\": \"aci-connector\",\n                \"enabled\": false\n            },\n            {\n                \"name\": \"kubernetes-dashboard\",\n                \"enabled\": false\n            },\n            {\n                \"name\": \"rescheduler\",\n                \"enabled\": true\n            }\n            ]\n        }\n        }\n    }\n    }\n",
      "jq '.properties.orchestratorProfile.kubernetesConfig.addons = \n     [.[] | if .name != \"rescheduler\" then .enabled = false else . end]' file",
      "(.properties.orchestratorProfile.kubernetesConfig.addons[]\n | select (.name != \"rescheduler\" ).enabled) = false"
    ],
    "utterance": "Set enabled to false for all elements in properties.orchestratorProfile.kubernetesConfig.addons where name is not \"rescheduler\", leaving enabled as true for rescheduler.",
    "expressions": [
      ".properties.orchestratorProfile.kubernetesConfig.addons = [.properties.orchestratorProfile.kubernetesConfig.addons[] | if .name != \"rescheduler\" then .enabled = false else . end]",
      "(.properties.orchestratorProfile.kubernetesConfig.addons[] | select (.name != \"rescheduler\" ).enabled) = false"
    ],
    "data": [
      {
        "input": {
          "apiVersion": "vlabs",
          "properties": {
            "orchestratorProfile": {
              "orchestratorType": "Kubernetes",
              "orchestratorRelease": "1.7",
              "orchestratorVersion": "1.7.10",
              "kubernetesConfig": {
                "kubernetesImageBase": "gcrio.azureedge.net/google_containers/",
                "clusterSubnet": "10.105.208.0/20",
                "networkPolicy": "calico",
                "nonMasqueradeCidr": "10.0.0.0/8",
                "maxPods": 110,
                "dockerBridgeSubnet": "172.17.0.1/16",
                "addons": [
                  {
                    "name": "tiller",
                    "enabled": true
                  },
                  {
                    "name": "aci-connector",
                    "enabled": true
                  },
                  {
                    "name": "kubernetes-dashboard",
                    "enabled": true
                  },
                  {
                    "name": "rescheduler",
                    "enabled": true
                  }
                ]
              }
            }
          }
        },
        "output": {
          "apiVersion": "vlabs",
          "properties": {
            "orchestratorProfile": {
              "orchestratorType": "Kubernetes",
              "orchestratorRelease": "1.7",
              "orchestratorVersion": "1.7.10",
              "kubernetesConfig": {
                "kubernetesImageBase": "gcrio.azureedge.net/google_containers/",
                "clusterSubnet": "10.105.208.0/20",
                "networkPolicy": "calico",
                "nonMasqueradeCidr": "10.0.0.0/8",
                "maxPods": 110,
                "dockerBridgeSubnet": "172.17.0.1/16",
                "addons": [
                  {
                    "name": "tiller",
                    "enabled": false
                  },
                  {
                    "name": "aci-connector",
                    "enabled": false
                  },
                  {
                    "name": "kubernetes-dashboard",
                    "enabled": false
                  },
                  {
                    "name": "rescheduler",
                    "enabled": true
                  }
                ]
              }
            }
          }
        }
      }
    ],
    "identifier": 47774666
  },
  {
    "context": [
      "cat ~/Desktop/config.json | jq '.Option = \"klay 10\"' | tee ~/Desktop/config.json",
      "cat ~/Desktop/config.json | jq \u2018.othOptions = \"-epool etc-eu1.nanopool.org:14324 -ewal 0xc63c1e59c54ca935bd491ac68fe9a7f1139bdbc0 -mode 1\"' | tee ~/Desktop/config.json",
      "using `tee` to overwrite the input file is a (well-known - see e.g. the jq [FAQ][1]) recipe for disaster. If you absolutely positively want to overwrite the file unconditionally, then you might want to consider using `sponge`, as in",
      "jq ... config.json | sponge config.json"
    ],
    "utterance": "Overwrite a file after setting the value of the othOptions key to a specific string: \"-epool etc-eu1.nanopool.org:14324 -ewal 0xc63c1e59c54ca935bd491ac68fe9a7f1139bdbc0 -mode 1\"",
    "expressions": [
      "jq '.othOptions = \"-epool etc-eu1.nanopool.org:14324 -ewal 0xc63c1e59c54ca935bd491ac68fe9a7f1139bdbc0 -mode 1\"' config.json | sponge config.json"
    ],
    "identifier": 47881580
  },
  {
    "context": [
      "How do I get a single output array like:\r\n\r\n    [\r\n      {\r\n        \"c\": \"xxx\"\r\n      },\r\n      {\r\n        \"c\": \"yyy\"\r\n      },\r\n      {\r\n        \"c\": \"zzz\"\r\n      }\r\n    ]",
      "You can use this:\r\n\r\n    jq '[{\"c\":(.a[].b[].c)}]' file.json",
      "This does it:\r\n\r\n    jq '[ .a[][][] ]'",
      "$ jq [.[][][][]] <<< \"$JSON\"",
      "OR:\r\n\r\n    $ jq '[.. | select(has(\"c\"))]' <<< \"$JSON\""
    ],
    "utterance": "Produce a single flattened array containing all objects with key c from nested arrays under key a.",
    "expressions": [
      "[{\"c\":(.a[].b[].c)}]",
      "[ .a[][][] ]",
      "[.[][][][]]",
      "[.. | select(has(\"c\"))]"
    ],
    "data": [
      {
        "input": {
          "a": [
            {
              "b": [
                {
                  "c": "xxx"
                }
              ]
            },
            {
              "b": [
                {
                  "c": "yyy"
                },
                {
                  "c": "zzz"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "c": "xxx"
          },
          {
            "c": "yyy"
          },
          {
            "c": "zzz"
          }
        ]
      }
    ],
    "identifier": 47894527
  },
  {
    "context": [
      "I want to automate it so that I can just pass values I want changed into bash script and then have those replaced where `newVal` is in my code above.",
      "I run `jq '.key = \"newVal\"'<config.json | sponge config.json` and this works for changing all the values I want, except...",
      "The issue is actually passing it into the value, in this case, neither `'$status'` nor `\"$status\"`, unfortunately.",
      "Am I maybe oversimplifying this, and I cannot just pass the positional param value to the .key in JSON?"
    ],
    "utterance": "Update an object's key to a new value provided as a shell positional parameter using an argument.",
    "expressions": [
      "jq --arg newVal \"$status\" '.key = $newVal' <config.json | sponge config.json"
    ],
    "identifier": 47901164
  },
  {
    "context": [
      "I want to use `jq` to select only those elements of the top array that contain the KV pair `animal == \"lion\"`.",
      "The output for the above JSON document should be:\n\n    {\n      \"KVs\" : [\n        {\n          \"Key\": \"animal\",\n          \"Value\": \"lion\"\n        },\n        {\n          \"Key\": \"mascot\",\n          \"Value\": \"lion\"\n        }\n      ],\n      \"name\": \"roger\"\n    }",
      "This is the solution:\n`.[] | select(.KVs[] | .Key == \"animal\" and .Value == \"lion\")`"
    ],
    "utterance": "Select objects from the array whose KVs array contains an object with Key equal to \"animal\" and Value equal to \"lion\".",
    "expressions": [
      ".[] | select(.KVs[] | .Key == \"animal\" and .Value == \"lion\")"
    ],
    "data": [
      {
        "input": [
          {
            "KVs": [
              {
                "Key": "animal",
                "Value": "lion"
              },
              {
                "Key": "mascot",
                "Value": "lion"
              }
            ],
            "name": "roger"
          },
          {
            "KVs": [
              {
                "Key": "animal",
                "Value": "zebra"
              },
              {
                "Key": "mascot",
                "Value": "lion"
              }
            ],
            "name": "linda"
          }
        ],
        "output": {
          "KVs": [
            {
              "Key": "animal",
              "Value": "lion"
            },
            {
              "Key": "mascot",
              "Value": "lion"
            }
          ],
          "name": "roger"
        }
      }
    ],
    "identifier": 47887535
  },
  {
    "context": [
      "defaultusernamealias=\"$(echo ${aliasConfig} | jq -r '.orgs | to_entries[] | select(.value ==\"'$defaultusername'\").key' )\"",
      "jq --arg username \"$defaultusername\" '\n  .orgs | to_entries[] | select(.value == $username ).key'",
      "$ jq --arg username \"$defaultusername\" --argjson JSON \"$aliasConfig\" '\n    $JSON\n    | .orgs | to_entries[] | select(.value == $username ).key'"
    ],
    "utterance": "Find the key in the 'orgs' object whose value equals the variable 'defaultusername'.",
    "expressions": [
      ".orgs | to_entries[] | select(.value == \"$defaultusername\").key",
      ".orgs | to_entries[] | select(.value == $username).key",
      "$JSON | .orgs | to_entries[] | select(.value == $username).key"
    ],
    "data": [
      {
        "input": {
          "orgs": {
            "HubOrg": "myemail@domain.com",
            "my-scrath-org": "test-jdj1iflkor4k@mydomain.net"
          }
        },
        "output": "my-scrath-org"
      }
    ],
    "identifier": 47917299
  },
  {
    "context": [
      "I\u2019m trying to use 'select(startswith(\"$variable\") )' but for some reason it doesn\u2019t work even though when I use the variable\u2019s value it works properly.",
      "Generally, the best way to pass the value of shell variables to a jq program is using the `-\u2014arg` and/or `\u2014-argjson` command-line options, as described in the manual.",
      "You can also do it without using `--arg` or `--argjson`. In your case, since your variable holds a string value, you may do it like this.\n\n    aws cloudformation describe-stacks --stack-name $StackName --region $region |\\\n    jq -r '.Stacks[].Outputs[].OutputKey | select(startswith('\\\"$App\\\"') )'\n\nNotice I added single quotation marks and escaped the double-quotation marks around your variable"
    ],
    "utterance": "Output all OutputKey values that start with the value stored in the shell variable $App.",
    "expressions": [
      "jq -r --arg app \"$App\" '.Stacks[].Outputs[].OutputKey | select(startswith($app))'"
    ],
    "identifier": 47939865
  },
  {
    "context": [
      "Using jq, given a name value (e.g. Christmas) how can I get it's associated id (i.e. 171).",
      "jq -r '.x[] | select(.name == \"Christmas\").id' file",
      "jq '.x[] | select(.name == \"Christmas\").id'"
    ],
    "utterance": "Find the id property for the object in the x array where name equals \"Christmas\".",
    "expressions": [
      ".x[] | select(.name == \"Christmas\").id"
    ],
    "data": [
      {
        "input": {
          "x": [
            {
              "name": "Hello",
              "id": "211"
            },
            {
              "name": "Goodbye",
              "id": "221"
            },
            {
              "name": "Christmas",
              "id": "171"
            }
          ],
          "y": "value"
        },
        "output": "171"
      }
    ],
    "identifier": 47939901
  },
  {
    "context": [
      "i want to convert this JSON into CSV lilke this,",
      "username email              total running apps api-mock-app flogo ipaas nodejs-app",
      "jack     jack@somewhere.com 1                  0            1     0     0",
      "jill     jill@somewhere.com 1                  0            1     0     0",
      "I tried this, and it worked perfectly,",
      "jq -r '(.users[0] | keys), (.users[] | [.username, .email, .\"total running apps\", .\"api-mock-app\", .flogo, .ipaas, .\"nodejs-app\"]) | @csv' temp.json",
      "jq -r '(.users[0] | keys_unsorted), (.users[] | to_entries | map(.value))|@csv' temp.json",
      "jq -r \"(.users[0] | keys_unsorted),  (.users[] | map(.) | @csv)\""
    ],
    "utterance": "Produce a CSV with a header and each user's data as rows, including the fields username, email, total running apps, api-mock-app, flogo, ipaas, and nodejs-app.",
    "expressions": [
      "jq -r '(.users[0] | keys), (.users[] | [.username, .email, .\"total running apps\", .\"api-mock-app\", .flogo, .ipaas, .\"nodejs-app\"]) | @csv' temp.json",
      "jq -r '(.users[0] | keys_unsorted), (.users[] | to_entries | map(.value))|@csv' temp.json",
      "jq -r '(.users[0] | keys_unsorted),  (.users[] | map(.) | @csv)'"
    ],
    "data": [
      {
        "input": {
          "users": [
            {
              "username": "jack",
              "email": "jack@somewhere.com",
              "total running apps": "1",
              "api-mock-app": "0",
              "flogo": "1",
              "ipaas": "0",
              "nodejs-app": "0"
            },
            {
              "username": "jill",
              "email": "jill@somewhere.com",
              "total running apps": "1",
              "api-mock-app": "0",
              "flogo": "1",
              "ipaas": "0",
              "nodejs-app": "0"
            }
          ]
        },
        "output": [
          "\"username\",\"email\",\"total running apps\",\"api-mock-app\",\"flogo\",\"ipaas\",\"nodejs-app\"",
          "\"jack\",\"jack@somewhere.com\",\"1\",\"0\",\"1\",\"0\",\"0\"",
          "\"jill\",\"jill@somewhere.com\",\"1\",\"0\",\"1\",\"0\",\"0\""
        ]
      }
    ],
    "identifier": 47730946
  },
  {
    "context": [
      "I'm looking for efficient means to search through an large JSON object for \"sub-objects\" that match a filter (via `select()`, I imagine).  However, the top-level JSON is an object with arbitrary nesting contained within, including more simple values, objects and arrays of objects.",
      "I have a solution which does **part of** what I want (and is understandable):",
      "jq -r '.. | arrays | .[] | select(.class==\"FINDME\"?) | .id'",
      "which returns:",
      "c2",
      "c1.1",
      "... however, it misses `c3`, plus it changes the order of items output.",
      "For small to modest-sized JSON input, you're on the right track with `..` but it seems you want to select `objects`, like so:",
      ".. | objects | select(.class==\"FINDME\"?) | .id",
      "For JSON documents that are very large, this might require too much memory, so it may be worth knowing about jq's streaming parser.",
      "Here's a streaming-parser solution.",
      "jq -n --stream -f program.jq input.json",
      "Output with sample input",
      "\"c1.1\"",
      "\"c2\"",
      "\"c3\""
    ],
    "utterance": "Find all object values of 'id' for every nested object where 'class' equals 'FINDME', including in objects that are not inside arrays.",
    "expressions": [
      ".. | objects | select(.class==\"FINDME\"?) | .id"
    ],
    "data": [
      {
        "input": {
          "name": "foo",
          "class": "system",
          "description": "top-level-thing",
          "configuration": {
            "status": "normal",
            "uuid": "id"
          },
          "children": [
            {
              "id": "c1",
              "class": "c1",
              "children": [
                {
                  "id": "c1.1",
                  "class": "c1.1"
                },
                {
                  "id": "c1.1",
                  "class": "FINDME"
                }
              ]
            },
            {
              "id": "c2",
              "class": "FINDME"
            }
          ],
          "thing": {
            "id": "c3",
            "class": "FINDME"
          }
        },
        "output": [
          "c2",
          "c1.1",
          "c3"
        ]
      }
    ],
    "identifier": 47891145
  },
  {
    "context": [
      "This is input json file\n    test.json\n    ---------\n            {\n              \"ParameterKey1\":  \"<value1>\",\n              \"Parameterkey2\":  \"<value2>\" \n             }\n",
      "Expected output: (final.json)\n      {\n          \"ParameterKey1\":  \"value\",\n          \"Parameterkey2\":  \"value\" \n         }\n",
      "That passes the shell variable to a jq dollar-variable, with the net effect of setting the jq variable $inp4 to the string-value of the shell variable $keypassword.  You can then use $inp4 as a jq variable, like any other -- so no quotation marks around it."
    ],
    "utterance": "Replace the values for 'ParameterKey1' and 'Parameterkey2' with provided input variable values only if their current values equal '<value1>' and '<value2>', respectively.",
    "expressions": [
      "jq --arg inp1 \"$value1\" --arg inp2 \"$value2\" 'if .ParameterKey1 == \"<value1>\" then .ParameterKey1 = $inp1 else . end | if .Parameterkey2 == \"<value2>\" then .Parameterkey2 = $inp2 else . end' test.json"
    ],
    "data": [
      {
        "input": {
          "ParameterKey1": "<value1>",
          "Parameterkey2": "<value2>"
        },
        "output": {
          "ParameterKey1": "value",
          "Parameterkey2": "value"
        }
      }
    ],
    "identifier": 47944079
  },
  {
    "context": [
      "I'm trying to parse the output of `AWS cli` using `jq` where the jq query contains bash variables and by using [the --arg switch][1] like so:",
      "$ aws ec2 describe-instances --region $region | jq --arg environment \"$Environment\" --arg br \"$BUILD_NUMBER\" --arg app \"$App\" -r '.Reservations[].Instances[].Tags[]?.Value | select(startswith(\"Company-$environment-$br-$app\"))'",
      "So what am I doing wrong?",
      "In jq, the expression you wrote:\n\n    \"Company-$environment-$br-$app\"\n\nis just a vanilla JSON string.",
      "One option would be to use jq's support for interpolation:\n\n    \"Company-\\($environment)-\\($br)-\\($app)\""
    ],
    "utterance": "Find all instance tag values that start with the concatenation of 'Company-', the given environment, build number, and app values passed as arguments.",
    "expressions": [
      ".Reservations[].Instances[].Tags[]?.Value | select(startswith(\"Company-\u007f($environment)-\u007f($br)-\u007f($app)\"))"
    ],
    "identifier": 47946718
  },
  {
    "context": [
      "I have the following output from `curl`ing Jenkins $BUILD_URL/api/json:",
      "I'm trying to extract the \"userId\" who started the build job as the current available Jenkins plugins which are supposed to do it don't work for some reason.",
      "I think it's related to the fact that there's no \".causes[]\" in some of the \".actions[]\" blocks, and if that's the case, is it possible to extract the \"userId\"?",
      "Using jq, you can protect against non-existence using the post-fix \"?\" operator, e.g. in your case:",
      "    .actions[].causes[]?.userId? | select(.)"
    ],
    "utterance": "Extract the userId of the user who started the build job, skipping actions without causes or userId.",
    "expressions": [
      ".actions[].causes[]?.userId? | select(.)"
    ],
    "data": [
      {
        "input": {
          "actions": [
            {
              "_class": "hudson.model.CauseAction",
              "causes": [
                {
                  "_class": "hudson.model.Cause$UserIdCause",
                  "shortDescription": "Started by user Itai Ganot",
                  "userId": "itaig",
                  "userName": "Itai Ganot"
                }
              ]
            },
            {
              "_class": "hudson.model.CauseAction",
              "causes": [
                {
                  "_class": "com.sonyericsson.rebuild.RebuildCause",
                  "shortDescription": "Rebuilds build #23",
                  "upstreamBuild": 23,
                  "upstreamProject": "Company-Analytics-Prod-Deploy_New",
                  "upstreamUrl": "view/Prod-US%20Deploy/job/Company-Analytics-Prod-Deploy_New/"
                }
              ]
            },
            {
              "_class": "hudson.model.ParametersAction",
              "parameters": [
                {
                  "_class": "eu.markov.jenkins.plugin.mvnmeta.MavenMetadataParameterValue",
                  "name": "Version"
                },
                {
                  "_class": "hudson.model.StringParameterValue",
                  "name": "region",
                  "value": "us-east-1"
                },
                {
                  "_class": "hudson.model.StringParameterValue",
                  "name": "StackName",
                  "value": "Company-Prd-21"
                },
                {
                  "_class": "hudson.model.StringParameterValue",
                  "name": "autostart",
                  "value": "No"
                }
              ]
            },
            {},
            {},
            {
              "_class": "hudson.plugins.git.util.BuildData",
              "buildsByBranchName": {
                "refs/remotes/origin/master": {
                  "_class": "hudson.plugins.git.util.Build",
                  "buildNumber": 24,
                  "buildResult": null,
                  "marked": {
                    "SHA1": "0e71efeac11c9909838453f4f103457ec3b04d27",
                    "branch": [
                      {
                        "SHA1": "0e71efeac11c9909838453f4f103457ec3b04d27",
                        "name": "refs/remotes/origin/master"
                      }
                    ]
                  },
                  "revision": {
                    "SHA1": "0e71efeac11c9909838453f4f103457ec3b04d27",
                    "branch": [
                      {
                        "SHA1": "0e71efeac11c9909838453f4f103457ec3b04d27",
                        "name": "refs/remotes/origin/master"
                      }
                    ]
                  }
                }
              },
              "lastBuiltRevision": {
                "SHA1": "0e71efeac11c9909838453f4f103457ec3b04d27",
                "branch": [
                  {
                    "SHA1": "0e71efeac11c9909838453f4f103457ec3b04d27",
                    "name": "refs/remotes/origin/master"
                  }
                ]
              },
              "remoteUrls": [
                "git@git.assembla.com:company.ci.git"
              ],
              "scmName": ""
            },
            {
              "_class": "hudson.plugins.git.GitTagAction"
            },
            {},
            {},
            {},
            {},
            {}
          ]
        },
        "output": [
          "itaig"
        ]
      }
    ],
    "identifier": 47942448
  },
  {
    "context": [
      "I want to take a set of flat fields, and add an array as a subObject to the main json.",
      "I want to output a single object that contains an array of batters with ID and their status.",
      "The following command will work against the `tmpData.txt` file",
      "` cat tmpData.txt | jq '{id, type} + {Batters: [(.batter[] | {batterId: .id, batterType: .type, status: .status.complete})]}'`"
    ],
    "utterance": "Create an object with the top-level fields 'id' and 'type', and add a key 'Batters' containing an array where each element has 'batterId', 'batterType', and 'status' fields derived from each batter.",
    "expressions": [
      "{id, type} + {Batters: [(.batter[] | {batterId: .id, batterType: .type, status: .status.complete})]}"
    ],
    "data": [
      {
        "input": {
          "id": "0001",
          "type": "donut",
          "name": "Cake",
          "ppu": 0.55,
          "batter": [
            {
              "id": "1001",
              "type": "Regular",
              "status": {
                "complete": false
              }
            },
            {
              "id": "1002",
              "type": "Chocolate",
              "status": {
                "complete": false
              }
            },
            {
              "id": "1003",
              "type": "Blueberry",
              "status": {
                "complete": false
              }
            },
            {
              "id": "1004",
              "type": "Devil's Food",
              "status": {
                "complete": false
              }
            }
          ]
        },
        "output": {
          "id": "0001",
          "type": "donut",
          "Batters": [
            {
              "batterId": "1001",
              "batterType": "Regular",
              "status": false
            },
            {
              "batterId": "1002",
              "batterType": "Chocolate",
              "status": false
            },
            {
              "batterId": "1003",
              "batterType": "Blueberry",
              "status": false
            },
            {
              "batterId": "1004",
              "batterType": "Devil's Food",
              "status": false
            }
          ]
        }
      }
    ],
    "identifier": 47982628
  },
  {
    "context": [
      "If I set temporary my locale in italian with `export LC_ALL=it_IT.utf8` and apply `.text|strptime(\"%d %B %Y\")` to",
      "{ \"text\": \"05 aprile 2017\" }",
      "I have `date \"05 aprile 2017\" does not match format \"%d %B %Y\"`.",
      "Ho to manage date localization settings with jq to recognize months local name?",
      "Currently (in v1.6), localization is not supported for date functionality."
    ],
    "utterance": "Parse a date string containing a month name in Italian using the %B format and obtain its representation as a time array.",
    "expressions": [
      ".text | strptime(\"%d %B %Y\")"
    ],
    "data": [
      {
        "input": {
          "text": "05 aprile 2017"
        }
      }
    ],
    "identifier": 48021870
  },
  {
    "context": [
      "I want to create an object \r\n\r\n    {\r\n        \"title\": \"Dummy1\",\r\n        \"title1\": \"Dummy2\",\r\n        \"title2\": \"Dummy3\",\r\n        \"title3\": \"Dummy4\"\r\n      }\r\n\r\nfrom the top one.",
      "extract the values of .id, and then turn each into an object of the form: `{(.id) : \"dummy\\(1+$i)\"}`",
      "map( .id )\r\n| . as $in\r\n| reduce range(0;length) as $i ({};\r\n    . + {($in[$i]): \"dummy\\(1+$i)\"})",
      "map(.id )\r\n| [., [range(0;length)]]\r\n| transpose\r\n| map( {(.[0]): \"dummy\\(.[1]+1)\"})\r\n| add"
    ],
    "utterance": "Create an object where each id from the array is a key, and the value is 'dummy' followed by its 1-based index, even if there are duplicate ids.",
    "expressions": [
      "map(.id) | . as $in | reduce range(0;length) as $i ({}; . + {($in[$i]): \"dummy\\(1+$i)\"})",
      "map(.id) | [., [range(0;length)]] | transpose | map({(.[0]): \"dummy\\(.[1]+1)\"}) | add"
    ],
    "data": [
      {
        "input": [
          {
            "id": "title",
            "description": "This is the Title",
            "defaultMessage": "title",
            "filepath": "src/title.js"
          },
          {
            "id": "title1",
            "description": "This is the Title1",
            "defaultMessage": "title1",
            "filepath": "src/title1.js"
          },
          {
            "id": "title2",
            "description": "This is the Title2",
            "defaultMessage": "title2",
            "filepath": "src/title2.js"
          },
          {
            "id": "title2",
            "description": "This is the Title2",
            "defaultMessage": "title2",
            "filepath": "src/title2.js"
          }
        ],
        "output": {
          "title": "dummy1",
          "title1": "dummy2",
          "title2": "dummy4"
        }
      }
    ],
    "identifier": 47983484
  },
  {
    "context": [
      "The endpoint value needs to be added to value attribute of values object where the key is \"URL\"",
      "Note: the key URL won't be always the first index of values.",
      "jq \\\n  --arg updateKey \"URL\" \\\n  --arg updateVal \"http://10.20.200.1\" \\\n  '.values = [.values[] | if (.key == $updateKey) then (.value = $updateVal) else . end]'",
      ".values = map( when(.key == $updateKey; .value = $updateVal) )"
    ],
    "utterance": "Update the value field to 'http://10.20.200.1' for the object in the values array where key equals 'URL'.",
    "expressions": [
      ".values = [.values[] | if (.key == $updateKey) then (.value = $updateVal) else . end]",
      "def when(c; f): if c? // null then f else . end; .values = map( when(.key == $updateKey; .value = $updateVal) )"
    ],
    "data": [
      {
        "input": {
          "id": "test1123",
          "name": "my testing",
          "values": [
            {
              "enabled": true,
              "key": "URL",
              "value": "http://localhost:3000/",
              "type": "text"
            },
            {
              "enabled": true,
              "key": "User1Token",
              "value": "",
              "type": "text"
            },
            {
              "enabled": true,
              "key": "User2Token",
              "value": "",
              "type": "text"
            },
            {
              "enabled": true,
              "key": "IdentityURL",
              "value": "",
              "type": "text"
            },
            {
              "enabled": true,
              "key": "AdminToken",
              "value": "",
              "type": "text"
            }
          ],
          "timestamp": 1511892974802,
          "_postman_variable_scope": "environment",
          "_postman_exported_at": "2017-11-28T19:38:23.389Z",
          "_postman_exported_using": "Postman/5.3.0"
        },
        "output": {
          "id": "test1123",
          "name": "my testing",
          "values": [
            {
              "enabled": true,
              "key": "URL",
              "value": "http://10.20.200.1",
              "type": "text"
            },
            {
              "enabled": true,
              "key": "User1Token",
              "value": "",
              "type": "text"
            },
            {
              "enabled": true,
              "key": "User2Token",
              "value": "",
              "type": "text"
            },
            {
              "enabled": true,
              "key": "IdentityURL",
              "value": "",
              "type": "text"
            },
            {
              "enabled": true,
              "key": "AdminToken",
              "value": "",
              "type": "text"
            }
          ],
          "timestamp": 1511892974802,
          "_postman_variable_scope": "environment",
          "_postman_exported_at": "2017-11-28T19:38:23.389Z",
          "_postman_exported_using": "Postman/5.3.0"
        }
      }
    ],
    "identifier": 47998378
  },
  {
    "context": [
      "How can I get both with a one liner containing a OR?",
      "One possibility would be to use `..`: .. | objects | select( has(\"name\") ) | .name",
      "or perhaps just: .. | .name? // empty",
      ".[] | (.name, .children[]?.name)",
      "Simplest form I think is: .. | .name?"
    ],
    "utterance": "Return all values of the 'name' property at any depth in the structure.",
    "expressions": [
      ".. | .name?",
      ".. | objects | select( has(\"name\") ) | .name",
      ".[] | (.name, .children[]?.name)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "asd",
            "children": [
              {
                "name": "sfgdfg"
              }
            ]
          }
        ],
        "output": [
          "asd",
          "sfgdfg"
        ]
      }
    ],
    "identifier": 48058260
  },
  {
    "context": [
      "I need to select the ids before id X. E.g. select ids before id 1 should return 2, 3 and 5.",
      "[.[].id] | to_entries | .[0:map(select(.value==1))[].key][].value",
      ".[0: map(.id) | index(1)]",
      "label $top | .[] | if .id == 1 then break $top else . end"
    ],
    "utterance": "Select all elements that appear before the element whose id equals 1.",
    "expressions": [
      ".[0: map(.id) | index(1)]",
      "label $top | .[] | if .id == 1 then break $top else . end",
      "[.[].id] | to_entries | .[0:map(select(.value==1))[].key][].value"
    ],
    "data": [
      {
        "input": [
          {
            "id": 2,
            "somekey": "somevalue"
          },
          {
            "id": 3,
            "somekey": "somevalue"
          },
          {
            "id": 5,
            "somekey": "somevalue"
          },
          {
            "id": 1,
            "somekey": "somevalue"
          },
          {
            "id": 4,
            "somekey": "somevalue"
          }
        ],
        "output": [
          {
            "id": 2,
            "somekey": "somevalue"
          },
          {
            "id": 3,
            "somekey": "somevalue"
          },
          {
            "id": 5,
            "somekey": "somevalue"
          }
        ]
      }
    ],
    "identifier": 48036567
  },
  {
    "context": [
      "When I run: `cat tmpData.txt | jq {'id: .id, type: .type, batterID: .batter[].id, batterType: .batter[].type'}`\n\nWith the added `type` field I get a lot of duplicates that wrongly associate items",
      "My ideal output would be like this\n\n   \n\n     [{\n    \"id\": \"0001\",\n    \"type\": \"donut\",\n    \"batterID\": \"1001\",\n    \"batterType\": \"Regular\"\n    },\n    {\n    \"id\": \"0001\",\n    \"type\": \"donut\",\n    \"batterID\": \"1002\",\n    \"batterType\": \"Chocolate\"\n    }]",
      "EDIT SOLVED: working command: `cat tmpData.txt | jq '[{id, type} + (.batter[] | {batterId: .id, batterType: .type})]'`",
      "Your filter which repeats .batter[] has the effect of creating a Cartesian product.  What you evidently want\ninstead is to expand .batter just once.",
      "Putting everything together:\n\n    [{id, type} + (.batter[] | {batterId: .id, batterType: .type})]"
    ],
    "utterance": "Extract an array of objects each containing id and type from the parent object, along with batterId and batterType for every element in the batter array.",
    "expressions": [
      "[{id, type} + (.batter[] | {batterId: .id, batterType: .type})]"
    ],
    "data": [
      {
        "input": {
          "id": "0001",
          "type": "donut",
          "name": "Cake",
          "ppu": 0.55,
          "batter": [
            {
              "id": "1001",
              "type": "Regular"
            },
            {
              "id": "1002",
              "type": "Chocolate"
            },
            {
              "id": "1003",
              "type": "Blueberry"
            },
            {
              "id": "1004",
              "type": "Devil's Food"
            }
          ]
        },
        "output": [
          {
            "id": "0001",
            "type": "donut",
            "batterId": "1001",
            "batterType": "Regular"
          },
          {
            "id": "0001",
            "type": "donut",
            "batterId": "1002",
            "batterType": "Chocolate"
          },
          {
            "id": "0001",
            "type": "donut",
            "batterId": "1003",
            "batterType": "Blueberry"
          },
          {
            "id": "0001",
            "type": "donut",
            "batterId": "1004",
            "batterType": "Devil's Food"
          }
        ]
      }
    ],
    "identifier": 47946183
  },
  {
    "context": [
      "Does anyone know how to use jq to find the duplicate(s) in a JSON array?",
      "Input: \n\n    [{\"foo\": 1, \"bar\": 2}, {\"foo\": 1, \"bar\": 2}, {\"foo\": 4, \"bar\": 5}]",
      "Output:\n\n  \t[{\"foo\": 1, \"bar\": 2}]",
      "group_by(.) | map(select(length>1) | .[0])",
      "def bagof(stream):\n  reduce stream as $x ({};\n    ($x | [type, tostring]) as $key\n    | getpath($key) as $entry\n    | if $entry then setpath($key; [$x, ($entry[1] + 1 )])\n      else setpath($key; [$x, 1])\n      end ) ;",
      "def duplicates(s): bagof(s) | .[][] | select(.[1]>1) | .[0];\n\ndef duplicates: [duplicates(.[])];"
    ],
    "utterance": "Find all objects that occur more than once in an array, emitting each duplicate only once.",
    "expressions": [
      "group_by(.) | map(select(length>1) | .[0])",
      "def bagof(stream): reduce stream as $x ({};\n  ($x | [type, tostring]) as $key\n  | getpath($key) as $entry\n  | if $entry then setpath($key; [$x, ($entry[1] + 1 )])\n    else setpath($key; [$x, 1])\n    end ) ;\ndef duplicates(s): bagof(s) | .[][] | select(.[1]>1) | .[0];\ndef duplicates: [duplicates(.[])];\nduplicates"
    ],
    "data": [
      {
        "input": [
          {
            "foo": 1,
            "bar": 2
          },
          {
            "foo": 1,
            "bar": 2
          },
          {
            "foo": 4,
            "bar": 5
          }
        ],
        "output": [
          {
            "foo": 1,
            "bar": 2
          }
        ]
      }
    ],
    "identifier": 48058204
  },
  {
    "context": [
      "I\u2019m using `jq` and trying to remove an element from an array based on it\u2019s value",
      "input = `[10,11,12]`",
      "`echo $input | jq -r 'map(select(. == 10))'` returns `[10]`",
      "`echo $input | jq -r 'del(select(. == 10))'` returns `[10,11,12]` not `[11,12]` as expected",
      "One way to achieve what you want is to use `select`:",
      "[10,11,12] | map(select(. != 10))",
      "Another would be to use array subtraction:",
      "[10,11,12] - [10]"
    ],
    "utterance": "Remove all instances of the number 10 from an array.",
    "expressions": [
      "map(select(. != 10))",
      ". - [10]"
    ],
    "data": [
      {
        "input": [
          10,
          11,
          12
        ],
        "output": [
          11,
          12
        ]
      }
    ],
    "identifier": 48078614
  },
  {
    "context": [
      "I wish to conditionally select like",
      "cat mydata.json | jq '.[] | select((.a > 50) and (.b > 50))'",
      "The problem is my original data is a string value and I have no idea how to parse it for a conditional selection.",
      "Simply with *jq*'s `tonumber` function:",
      "jq '.[] | select((.a|tonumber) > 50 and (.b|tonumber) > 50)' mydata.json"
    ],
    "utterance": "Select array objects where field a as a float is greater than 50 and field b as a float is greater than 50",
    "expressions": [
      ".[] | select((.a|tonumber) > 50 and (.b|tonumber) > 50)"
    ],
    "data": [
      {
        "input": [
          {
            "a": "0",
            "b": "66.67",
            "c": "0",
            "d": "0"
          },
          {
            "a": "12.33",
            "b": "0",
            "c": "60.2",
            "d": "19.3"
          },
          {
            "a": "70.0",
            "b": "92.67",
            "c": "0",
            "d": "0"
          }
        ],
        "output": {
          "a": "70.0",
          "b": "92.67",
          "c": "0",
          "d": "0"
        }
      }
    ],
    "identifier": 48077471
  },
  {
    "context": [
      "jq --arg input \"$username\" \\\n              'if .key1 == \"<value1>\"\n                     then . + {\"key1\" : ($input) }\n              else . end' input.json |\n              'if .key2 == \"<value2>\"\n                     then . + {\"key2\" : ($input) }\n              else . end'  >  output.json",
      "output.json\n-----------\n\n    {\n    \"key1\": \"jack\",\n    \"key2\": \"jack\"\n    }",
      "if .key1 == \"\" then . + {\"key1\" : $input } else . end\n| if .key2 == \"\" then . + {\"key2\" : $input } else . end",
      "if .key1 == \"\" then .key1 = $input else . end\n| if .key2 == \"\" then .key2 = $input else . end",
      "def update(f): f |= (if . == \"\" then $input else . end);\nupdate(.key1) | update(.key2)"
    ],
    "utterance": "Set key1 and key2 to the specified input value if they are empty strings.",
    "expressions": [
      "if .key1 == \"\" then . + {\"key1\" : $input } else . end | if .key2 == \"\" then . + {\"key2\" : $input } else . end",
      "if .key1 == \"\" then .key1 = $input else . end | if .key2 == \"\" then .key2 = $input else . end",
      "def update(f): f |= (if . == \"\" then $input else . end); update(.key1) | update(.key2)"
    ],
    "data": [
      {
        "input": {
          "key1": "",
          "key2": ""
        },
        "output": {
          "key1": "jack",
          "key2": "jack"
        }
      }
    ],
    "identifier": 48072308
  },
  {
    "context": [
      "I am trying to get the name and the create date out of this using bash with jq, so for with little to no success.",
      "jq '.newList' does work and brings me down one level, but that's not sufficient.",
      "jq '.newList .243' gives me a compile error. Furthermore, the 243 is dynamic and can change at any time.",
      "api-producing-json | jq --raw-output '.newList[] | \"\\(.id) \\(.name) \\(.create.date)\"'",
      "To process further in a loop, you can iterate it over a bash loop, ... api-producing-json | jq --raw-output '.newList[] | \"\\(.id)|\\(.name)|\\(.create.date)\"'",
      "To discard the keys, we can use the values filter... our solution is going to look something like cat input.json | jq ' .newList | values | map(some_filter) '.",
      "cat input.json | jq '\n      def details_to_string:\n          . | \"Details: \\(id), \\(.name), \\(.create.date)\";\n\n      .newList | values | map(details_to_string)\n'",
      "If you just want the individual strings (no square brackets, no commas) then you can split the array open at the end. ( `.newList | values | map(details_to_string) | .[]` ). If you also change 'jq' to 'jq -r' then you'll get rid of the quote marks as well"
    ],
    "utterance": "Extract each object's id, name, and creation date from the newList object, regardless of key names.",
    "expressions": [
      ".newList[] | \"\\(.id) \\(.name) \\(.create.date)\"",
      ".newList[] | \"\\(.id)|\\(.name)|\\(.create.date)\"",
      ".newList | values | map(\"\\(.id) \\(.name) \\(.create.date)\") | .[]",
      ".newList | map(\"\\(.id) \\(.name) \\(.create.date)\") | .[]",
      ".newList | values | map(\"\u0000(.id) \u0000(.name) \u0000(.create.date)\") | .[]"
    ],
    "data": [
      {
        "input": {
          "newList": {
            "243": {
              "id": "243",
              "name": "test",
              "create": {
                "date": "2017-08-31 13:57:29"
              }
            },
            "244": {
              "id": "244",
              "name": "test",
              "create": {
                "date": "2017-08-31 13:57:29"
              }
            }
          }
        },
        "output": [
          "243 test 2017-08-31 13:57:29",
          "244 test 2017-08-31 13:57:29"
        ]
      }
    ],
    "identifier": 48005870
  },
  {
    "context": [
      "We are trying to get `jq`v1.5 64bit to parse an array then echo out the result.",
      "nameArr=( \"Leia\" \"Darth Vader\" \"Anakin\" \"Han Solo\" \"Yoda\" )",
      "jq -c -n  \"$nameArr\"",
      "printf '%s\\0' \"${nameArr[@]}\" | jq -csR 'split(\"\\u0000\")'",
      "...properly emits:",
      "[\"Leia\",\"Darth Vader\",\"Anakin\",\"Han Solo\",\"Yoda\"]"
    ],
    "utterance": "Convert a shell array containing the names Leia, Darth Vader, Anakin, Han Solo, and Yoda into a compact array and output the result.",
    "expressions": [
      "jq -csR 'split(\"\\u0000\")'"
    ],
    "data": [
      {
        "input": "Leia\u0000Darth Vader\u0000Anakin\u0000Han Solo\u0000Yoda\u0000",
        "output": [
          "Leia",
          "Darth Vader",
          "Anakin",
          "Han Solo",
          "Yoda"
        ]
      }
    ],
    "identifier": 48082550
  },
  {
    "context": [
      "echo $normaltext | jq --slurp --raw-input",
      "escapedtext=$(echo $normaltext | jq --slurp --raw-input)",
      "Your version of jq evidently requires the `.` filter here, as in:",
      "jq -s -R ."
    ],
    "utterance": "Escape a string with special characters and assign the properly escaped output to a shell variable.",
    "expressions": [
      "jq -s -R ."
    ],
    "identifier": 48090023
  },
  {
    "context": [
      "In the last but one column I'd like to truncate precision to 3 digits after the dot and in the last column I'd like to divide by 1M. In the json these fields are strings. I'm forced to use [jq][1].",
      "curl -s \"https://api.coinmarketcap.com/v1/ticker/?convert=EUR&limit=20\" | jq -r '.[] | [.rank, .symbol, .percent_change_1h, .percent_change_24h, .percent_change_7d, .price_eur, .market_cap_eur] | @tsv'"
    ],
    "utterance": "Output rank, symbol, percent_change_1h, percent_change_24h, percent_change_7d, price_eur (rounded to 3 decimal places), and market_cap_eur divided by 1,000,000 for each item.",
    "expressions": [
      ".[] | [.rank, .symbol, .percent_change_1h, .percent_change_24h, .percent_change_7d, (.price_eur|tonumber|tostring|match(\"^\\d+\\.\\d{0,3}\")|.string), ((.market_cap_eur|tonumber)/1000000)] | @tsv",
      ".[] | [.rank, .symbol, .percent_change_1h, .percent_change_24h, .percent_change_7d, ((.price_eur|tonumber*1000|floor/1000)|tostring), ((.market_cap_eur|tonumber)/1000000)] | @tsv"
    ],
    "identifier": 48100901
  },
  {
    "context": [
      "I want to convert the dates to epoch seconds so I can sort them. But this format doesn't quite match what strptime will accept:",
      "So, if I just strip off the last 5 characters I can use the same format, minus the %z. This works:",
      "$ jq '.files[] | .date[0:19]' files.json ",
      "> jq '.files[] | map( .date |= .date[0:19] )' files.json ",
      "You can either write `.date = .date[0:19]`, or (better): `.date |= .[0:19]`",
      "It's not entirely clear what you want, but if the goal is simply to edit the JSON, then one option would be:",
      ".files |= map( .date |= .[0:19] )"
    ],
    "utterance": "Replace each object's date field with its first 19 characters for all objects in the files array.",
    "expressions": [
      ".files |= map(.date |= .[0:19])"
    ],
    "data": [
      {
        "input": {
          "files": [
            {
              "date": "2018-01-08T11:38:36+00:00"
            },
            {
              "date": "2018-01-08T11:38:27+00:00"
            },
            {
              "date": "2018-01-07T20:02:12+00:00"
            },
            {
              "date": "2018-01-07T18:23:26+00:00"
            }
          ]
        },
        "output": {
          "files": [
            {
              "date": "2018-01-08T11:38:36"
            },
            {
              "date": "2018-01-08T11:38:27"
            },
            {
              "date": "2018-01-07T20:02:12"
            },
            {
              "date": "2018-01-07T18:23:26"
            }
          ]
        }
      }
    ],
    "identifier": 48175679
  },
  {
    "context": [
      "I need to combine them in one big file with the same structure:",
      "But the result is:",
      "Any idea is appreciated.",
      "If that's the case and if your file list is file1 file2 ... then the following invocation would be appropriate:",
      "jq add file1 file2 ...",
      "Using the -s option will return an array containing the contents of the input JSON files, which, in your case, are also arrays. This means that you need to spread (\u2026[]) two array levels, and collect ([\u2026]) the result.",
      "jq -s '[.[][]]' a-*.json > manifest.json",
      "I was able to solve this with:",
      "jq -s 'flatten' file1 file2 ...",
      "So -s (slurp) assembles an array of files' contents (arrays), and flatten removes the extra [] levels and the output is an array of all records from all files."
    ],
    "utterance": "Combine the elements from multiple files, where each file contains an array of objects, into a single flat array containing all objects from all files.",
    "expressions": [
      "jq -s '[.[][]]' file1 file2",
      "jq -s 'flatten' file1 file2"
    ],
    "data": [
      {
        "input": [
          [
            {
              "bent_general": "0",
              "bext_general": "0",
              "date_yyyymmdd": "20171104",
              "end_time": "2017-11-07T02:58:56",
              "householdid": "EAM2231"
            },
            {
              "bent_general": "2",
              "bext_general": "8",
              "date_yyyymmdd": "20171126",
              "end_time": "2017-12-07T05:58:56",
              "householdid": "EAM1234"
            }
          ],
          [
            {
              "bent_general": "3",
              "bext_general": "5",
              "date_yyyymmdd": "20171201",
              "end_time": "2017-12-10T08:00:00",
              "householdid": "EAM5678"
            }
          ]
        ],
        "output": [
          {
            "bent_general": "0",
            "bext_general": "0",
            "date_yyyymmdd": "20171104",
            "end_time": "2017-11-07T02:58:56",
            "householdid": "EAM2231"
          },
          {
            "bent_general": "2",
            "bext_general": "8",
            "date_yyyymmdd": "20171126",
            "end_time": "2017-12-07T05:58:56",
            "householdid": "EAM1234"
          },
          {
            "bent_general": "3",
            "bext_general": "5",
            "date_yyyymmdd": "20171201",
            "end_time": "2017-12-10T08:00:00",
            "householdid": "EAM5678"
          }
        ]
      }
    ],
    "identifier": 48081944
  },
  {
    "identifier": 48222990
  },
  {
    "context": [
      "If values of some defined keys are matching, I'd like to merge the entries. The data which does not match should be stored in an array.",
      "If the street and the house number are identical, I'd like to merge this entry and put the values of \"member\" into an array.",
      "**Matching keys**: housenumber + street have to be identical.",
      "Target result:\n\n    [{\n     \"street\"  : \"Foobar ave\",\n     \"housenumber\": 4,\n     \"members\":[\"Carl\",\"Bernd\"]\n     },\n     {\n     \"street\"  : \"Foobar ave\",\n     \"housenumber\": 2,\n     \"members\":[\"Ann\"]\n     }]",
      "GROUPS_BY(.[]; [.street, .housenumber])\n| (.[0]|del(.member)) + { members: (map(.member)) }",
      "If you require that the result be an array, then simply wrap the two-line program above in square brackets: [ .... ]",
      "group_by( [.street, .housenumber])\n| map((.[0]|del(.member)) + { members: (map(.member)) })"
    ],
    "utterance": "Group objects with identical street and housenumber, and output one object per group with those keys and a members array of all member values.",
    "expressions": [
      "[GROUPS_BY(.[]; [.street, .housenumber]) | (.[0] | del(.member)) + {members: (map(.member))}]",
      "group_by([.street, .housenumber]) | map((.[0] | del(.member)) + {members: map(.member)})"
    ],
    "data": [
      {
        "input": [
          {
            "street": "Foobar ave",
            "housenumber": 4,
            "member": "Carl"
          },
          {
            "street": "Foobar ave",
            "housenumber": 4,
            "member": "Bernd"
          },
          {
            "street": "Foobar ave",
            "housenumber": 2,
            "member": "Ann"
          }
        ],
        "output": [
          {
            "street": "Foobar ave",
            "housenumber": 4,
            "members": [
              "Carl",
              "Bernd"
            ]
          },
          {
            "street": "Foobar ave",
            "housenumber": 2,
            "members": [
              "Ann"
            ]
          }
        ]
      }
    ],
    "identifier": 48155814
  },
  {
    "context": [
      "I want the sum of \"count\" - \"number of un-used\" that is under \"y\".",
      "cat json | jq '.[] | .[].y | .[\"number of un-used\"] | .count'",
      "But the results contains a lot of \"null\" because \"number of un-used\" is not in all of \"y\" dicts..",
      "You can add zero to a null to get ... zero.",
      "jq '.[] | .[].y | .\"number of un-used\" | .count + 0' < input.json",
      "jq can do basic arithmetic in its expressions, but having it calculate your sum internally gets a little more complex.",
      "def sigma(s): reduce s as $x (0; .+$x);",
      "sigma(.[].[].y | .[\"number of un-used\"] | .count)"
    ],
    "utterance": "Calculate the sum of all 'count' values under 'number of un-used' within each 'y', treating missing values as zero.",
    "expressions": [
      ".[] | .[].y | .[\"number of un-used\"] | .count + 0",
      "reduce (.[].[].y | .[\"number of un-used\"] | .count + 0) as $x (0; .+$x)",
      "def sigma(s): reduce s as $x (0; .+$x); sigma(.[].[].y | .[\"number of un-used\"] | .count)"
    ],
    "data": [
      {
        "input": {
          "main": {
            "0": {
              "x": {
                "a": 1
              },
              "y": {
                "number of un-used": {
                  "count": 2
                },
                "z": 2
              }
            },
            "1": {
              "x": {
                "a": 1
              },
              "y": {
                "number of un-used": {
                  "count": 3
                },
                "z": 2
              }
            },
            "2": {
              "x": {
                "a": 1
              },
              "y": {
                "number of un-used": {
                  "count": 4
                },
                "z": 2
              }
            },
            "3": {
              "x": {
                "a": 1
              },
              "y": {
                "no un-used": {
                  "z": 3
                },
                "z": 2
              }
            },
            "4": {
              "x": {
                "a": 1
              },
              "y": {
                "no un-used": {
                  "z": 3
                },
                "z": 2
              }
            }
          },
          "no-main": {
            "0": {
              "x": {
                "a": 1
              },
              "y": {
                "number of un-used": {
                  "count": 2
                },
                "z": 2
              }
            },
            "1": {
              "x": {
                "a": 1
              },
              "y": {
                "number of un-used": {
                  "count": 3
                },
                "z": 2
              }
            },
            "2": {
              "x": {
                "a": 1
              },
              "y": {
                "number of un-used": {
                  "count": 4
                },
                "z": 2
              }
            },
            "3": {
              "x": {
                "a": 1
              },
              "y": {
                "no un-used": {
                  "z": 3
                },
                "z": 2
              }
            },
            "4": {
              "x": {
                "a": 1
              },
              "y": {
                "no un-used": {
                  "z": 3
                },
                "z": 2
              }
            }
          }
        },
        "output": 18
      }
    ],
    "identifier": 48205247
  },
  {
    "context": [
      "Is there any jq command that extracts the decoded \"5f b7 5f\" byte sequence out of this JSON?",
      "{ \"key\": \"_\\u00b7_\" } | .key | explode | map(hx)",
      "produces:",
      "[\"5F\",\"B7\",\"5F\"]"
    ],
    "utterance": "Extract the Unicode codepoints as hexadecimal values from the string value associated with the key 'key', where the value is '_\\u00b7_'.",
    "expressions": [
      "def hx: def hex: [if . < 10 then 48 + . else  55 + . end] | implode ; tonumber | \"\\(./16 | floor | hex)\\(. % 16 | hex)\"; {\"key\":\"_\\u00b7_\"} | .key | explode | map(hx)"
    ],
    "data": [
      {
        "input": {
          "key": "_\u0000b7_"
        },
        "output": [
          "5F",
          "B7",
          "5F"
        ]
      }
    ],
    "identifier": 48240055
  },
  {
    "context": [
      "I need to replace all occurrences of a string with a different string in the whole body of a JSON in JQ.",
      "Say in the following input JSON I want to replace the string \"DEV\" with \"INT\". How could I do this in JQ?",
      "walk(if type == \"string\" then gsub(\"DEV\"; \"INT\") else . end)"
    ],
    "utterance": "Replace every occurrence of the string \"DEV\" with \"INT\" throughout all string values in the entire JSON object.",
    "expressions": [
      "walk(if type == \"string\" then gsub(\"DEV\"; \"INT\") else . end)"
    ],
    "data": [
      {
        "input": {
          "startIndex": 0,
          "vXPolicies": [
            {
              "policyName": "DEVXPolicyDEF",
              "tables": "DEVX_DE_DEF"
            },
            {
              "policyName": "DEVXPolicyABC",
              "tables": "DEVX_DE_ABC"
            }
          ]
        },
        "output": {
          "startIndex": 0,
          "vXPolicies": [
            {
              "policyName": "INTXPolicyDEF",
              "tables": "INTX_DE_DEF"
            },
            {
              "policyName": "INTXPolicyABC",
              "tables": "INTX_DE_ABC"
            }
          ]
        }
      }
    ],
    "identifier": 48254985
  },
  {
    "context": [
      "How to format this JSON with jq to display it in such way:",
      "{\r\n    \"name\": \"child 1\",\r\n    \"parent_name\": \"parent 1\",\r\n    \"system_name\": \"cisco 1\"\r\n    }",
      "{\r\n    \"name\": \"parent 1\",\r\n    \"parent_name\": null,\r\n    \"system_name\": \"sys 1 name\"\r\n    }",
      "Except for the ordering, the following jq program produces the desired output, as shown below:",
      "..\n| select(.name? and .system_name?)\n| {name, parent_name, system_name}"
    ],
    "utterance": "Extract all objects with a 'name' and 'system_name' property, and output their 'name', 'parent_name', and 'system_name' as separate objects.",
    "expressions": [
      ".. | select(.name? and .system_name?) | {name, parent_name, system_name}"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "type": "physical",
              "children": [
                {
                  "children": [
                    {
                      "type": "CISCO",
                      "description": "test",
                      "id": 53,
                      "min_max_policy": {
                        "legal_hold": 0,
                        "name": "child 1",
                        "max": 60,
                        "min": 0
                      },
                      "name": "child 1",
                      "parent_id": 1,
                      "parent_name": "parent 1",
                      "system_id": 1,
                      "system_name": "cisco 1",
                      "version": "None"
                    },
                    {
                      "type": "CISCO",
                      "description": "test",
                      "id": 54,
                      "min_max_policy": {
                        "legal_hold": 0,
                        "name": "child 2",
                        "max": 60,
                        "min": 0
                      },
                      "name": "child 2",
                      "parent_id": 1,
                      "parent_name": "parent 1",
                      "system_id": 2,
                      "system_name": "cisco 1",
                      "version": "None"
                    }
                  ],
                  "type": "network devices"
                }
              ],
              "machine_type": "X32",
              "min_max_policy": {
                "id": 1,
                "name": "parent 1",
                "max": 60,
                "min": 0
              },
              "name": "parent 1",
              "system_id": 1,
              "system_name": "sys 1 name",
              "version": "1.0"
            },
            {
              "type": "physical",
              "children": [
                {
                  "children": [
                    {
                      "type": "HP",
                      "description": "test",
                      "id": 55,
                      "min_max_policy": {
                        "legal_hold": 0,
                        "name": "child 3",
                        "max": 60,
                        "min": 0
                      },
                      "name": "child 3",
                      "parent_id": 2,
                      "parent_name": "parent 2",
                      "system_id": 3,
                      "system_name": "hp 1",
                      "version": "None"
                    }
                  ],
                  "type": "network devices"
                }
              ],
              "machine_type": "X32",
              "min_max_policy": {
                "id": 2,
                "legal_hold": 0,
                "name": "parent 2",
                "max": 60,
                "min": 0
              },
              "name": "parent 2",
              "system_id": 2,
              "system_name": "sys 2 name",
              "version": "1.0"
            },
            {
              "type": "physical",
              "machine_type": "X32",
              "min_max_policy": {
                "id": 3,
                "name": "parent 3",
                "max": 60,
                "min": 0
              },
              "name": "parent 3",
              "system_id": 3,
              "system_name": "sys 3 name",
              "version": "1.0"
            }
          ]
        },
        "output": [
          {
            "name": "parent 1",
            "parent_name": null,
            "system_name": "sys 1 name"
          },
          {
            "name": "child 1",
            "parent_name": "parent 1",
            "system_name": "cisco 1"
          },
          {
            "name": "child 2",
            "parent_name": "parent 1",
            "system_name": "cisco 1"
          },
          {
            "name": "parent 2",
            "parent_name": null,
            "system_name": "sys 2 name"
          },
          {
            "name": "child 3",
            "parent_name": "parent 2",
            "system_name": "hp 1"
          },
          {
            "name": "parent 3",
            "parent_name": null,
            "system_name": "sys 3 name"
          }
        ]
      }
    ],
    "identifier": 48000460
  },
  {
    "context": [
      "What I'm after is this:\n\n    \"latitude\",\"longitude\",\"drivingDifficultyIndex\",\"iconCode\",\"observationTimeUtcIso\",\"precip1Hour\"\n    39.582,    26.675,    0,    31,    \\2016-06-26T00:20:00+0000\\\",    0\n    39.582,    26.675,    34,    11,    \\\"2016-06-26T01:20:00+0000\\\",    0.1\n    39.582,    26.675,    34,    11,    \\\"2016-06-26T02:20:00+0000\\\",    0.5",
      "But how can I get this to work to account for much larger (unknown) number of array elements?",
      "Indeed, using `transpose` allows a simple, one-line solution along the lines you envisioned:\n\n    ( keys_unsorted, ([.[]] | transpose)[]) | @csv",
      "With the sample data, invocation of jq with the -r option yields:\n\n    \n    \"latitude\",\"longitude\",\"drivingDifficultyIndex\",\"iconCode\",\"observationTimeUtcIso\",\"precip1Hour\"\n    39.582,26.675,0,31,\"2016-06-26T00:20:00+0000\",0\n    39.582,26.675,34,11,\"2016-06-26T01:20:00+0000\",0.1\n    39.582,26.675,34,11,\"2016-06-26T02:20:00+0000\",0.5"
    ],
    "utterance": "Convert an object where values are arrays of equal length into CSV rows, with each row representing one index across all arrays, and the first row as column headers.",
    "expressions": [
      "(keys_unsorted, ([.[]] | transpose)[]) | @csv"
    ],
    "data": [
      {
        "input": {
          "latitude": [
            39.582,
            39.582,
            39.582
          ],
          "longitude": [
            26.675,
            26.675,
            26.675
          ],
          "drivingDifficultyIndex": [
            0,
            34,
            34
          ],
          "iconCode": [
            31,
            11,
            11
          ],
          "observationTimeUtcIso": [
            "2016-06-26T00:20:00+0000",
            "2016-06-26T01:20:00+0000",
            "2016-06-26T02:20:00+0000"
          ],
          "precip1Hour": [
            0.0,
            0.1,
            0.5
          ]
        },
        "output": [
          "\"latitude\",\"longitude\",\"drivingDifficultyIndex\",\"iconCode\",\"observationTimeUtcIso\",\"precip1Hour\"",
          "39.582,26.675,0,31,\"2016-06-26T00:20:00+0000\",0",
          "39.582,26.675,34,11,\"2016-06-26T01:20:00+0000\",0.1",
          "39.582,26.675,34,11,\"2016-06-26T02:20:00+0000\",0.5"
        ]
      }
    ],
    "identifier": 48224065
  },
  {
    "context": [
      "I have a json object with a field which can have a string or an array value.",
      "I want to transform roles field to a csv, and keep the rest of the fields as is.",
      ".roles |= if type == \"array\" then join(\",\") else . end",
      ".roles |= if type == \"array\" then map(tostring)|join(\",\") else . end"
    ],
    "utterance": "Convert the 'roles' field to a comma-separated string if it is an array, leaving all other fields unchanged.",
    "expressions": [
      ".roles |= if type == \"array\" then join(\",\") else . end",
      ".roles |= if type == \"array\" then map(tostring) | join(\",\") else . end"
    ],
    "data": [
      {
        "input": {
          "roles": [
            "ADMIN",
            "USER"
          ],
          "user_id": 100,
          "message": "abc added a user xyz",
          "level": "info",
          "created_at": "2014-10-12 14:06:37"
        },
        "output": {
          "roles": "ADMIN,USER",
          "user_id": 100,
          "message": "abc added a user xyz",
          "level": "info",
          "created_at": "2014-10-12 14:06:37"
        }
      },
      {
        "input": {
          "roles": "ADMIN",
          "user_id": 102,
          "message": "a added a user b",
          "level": "info",
          "created_at": "2014-10-12 14:06:37"
        },
        "output": {
          "roles": "ADMIN",
          "user_id": 102,
          "message": "a added a user b",
          "level": "info",
          "created_at": "2014-10-12 14:06:37"
        }
      }
    ],
    "identifier": 48258020
  },
  {
    "context": [
      "I have a json file in the form of a key-value map. For example:\n\n    {\n        \"users\":[\n        {\n            \"key1\":\"user1\",\n            \"key2\":\"user2\"\n        }\n      ]\n    }\n",
      "I have another json file. The values in the second file has to be replaced based on the keys in first file.",
      "For example 2nd file is:\n\n    {\n        \"info\":\n        {\n        \"users\":[\"key1\",\"key2\",\"key3\",\"key4\"]\n        }\n    }\n\nThis second file should be replaced with \n\n    {\n        \"info\":\n        {\n        \"users\":[\"user1\",\"user2\",\"key3\",\"key4\"]\n        }\n    }\n",
      "jq --slurpfile users 1st.json '$users[0].users[0] as $users \n     | .info.users |= map(if in($users) then $users[.] else . end)' 2nd.json",
      "$users[0].users[0] as $dict\n| .info.users |= map($dict[.] // .)"
    ],
    "utterance": "Replace each element in the info.users array with the corresponding value from the users dictionary if present; otherwise, keep the element unchanged.",
    "expressions": [
      "$users[0].users[0] as $users | .info.users |= map(if in($users) then $users[.] else . end)",
      "$users[0].users[0] as $dict | .info.users |= map($dict[.] // .)"
    ],
    "data": [
      {
        "input": {
          "users": [
            {
              "key1": "user1",
              "key2": "user2"
            }
          ]
        }
      },
      {
        "input": {
          "info": {
            "users": [
              "key1",
              "key2",
              "key3",
              "key4"
            ]
          }
        },
        "output": {
          "info": {
            "users": [
              "user1",
              "user2",
              "key3",
              "key4"
            ]
          }
        }
      }
    ],
    "identifier": 48285020
  },
  {
    "context": [
      "What I need to do is then post it to another system via HTTP.",
      "What I'm struggling with is getting this value into a clean format I can use...",
      "Given the JSON shown, the jq query:\n\n    .results[].series[].values[]\n\nproduces:\n\n    [\n      \"2018-01-17T04:15:30Z\",\n      690.1\n    ]\n",
      "you might want to consider a variant, such as:\n\n    .results[-1].series[-1].values[-1]\n\nwhich in this case produces the same result, as it happens.",
      "If you just want the atomic values, you could simply append [] to either of the queries above.",
      "Pipe that curl to the jq below \n\n    $ your_curl_stuff_here | jq '.results[].series[]|.name,.values[0][]'\n    \"grid\"\n    \"2018-01-17T04:15:30Z\"\n    690.1\n"
    ],
    "utterance": "Extract the last inserted value and its timestamp from the query result, producing the clean numeric value for use in subsequent commands.",
    "expressions": [
      ".results[].series[].values[][1]",
      ".results[-1].series[-1].values[-1][1]"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "statement_id": 0,
              "series": [
                {
                  "name": "grid",
                  "columns": [
                    "time",
                    "last"
                  ],
                  "values": [
                    [
                      "2018-01-17T04:15:30Z",
                      690.1
                    ]
                  ]
                }
              ]
            }
          ]
        },
        "output": 690.1
      }
    ],
    "identifier": 48293564
  },
  {
    "context": [
      "However, this crashes if any user doesn't have `items`:",
      "jq: error (at <stdin>:5): null (null) cannot be sorted, as it is not an array",
      "How can I obtain the following?",
      "[",
      "  {",
      "    \"items\": [",
      "      \"bar\",",
      "      \"foo\"",
      "    ]",
      "  },",
      "  {",
      "    \"items\": [",
      "      \"bar\",",
      "      \"foo\"",
      "    ]",
      "  },",
      "  {",
      "    \"items\": [",
      "    ]",
      "  }",
      "]",
      "Aha, this seems to work:",
      "$ jq < users.json 'map(.items |= (. // [])) | map(.items |= sort)'",
      "map_values(if has(\"items\") then .items |= sort else . end)",
      "map_values(.items |= (. // [] | sort))"
    ],
    "utterance": "Sort each user's items array, substituting an empty array when items is missing.",
    "expressions": [
      "map(.items |= (. // [])) | map(.items |= sort)",
      "map_values(.items |= (. // [] | sort))"
    ],
    "data": [
      {
        "input": {
          "alice": {
            "items": [
              "foo",
              "bar"
            ]
          },
          "bob": {
            "items": [
              "bar",
              "foo"
            ]
          },
          "charlie": {}
        },
        "output": {
          "alice": {
            "items": [
              "bar",
              "foo"
            ]
          },
          "bob": {
            "items": [
              "bar",
              "foo"
            ]
          },
          "charlie": {
            "items": []
          }
        }
      }
    ],
    "identifier": 48306264
  },
  {
    "context": [
      "how to prettyprint a single-quoted JSON file using jq",
      "The sample is not valid JSON.",
      "At least one of the tools mentioned in the above-referenced section in the jq FAQ (jsonlint) will not only convert single-quoted quasi-JSON to JSON, but also pretty-print it.",
      "In the example you gave, you could use `sed` or even `tr` in conjunction with jq:",
      "echo \"{ 'abc': { 'name': 'John', 'address': 'USA' }, 'xyz': { 'name': 'Robert', 'address': 'Canada' } }\" |\n  tr \"'\" '\"' | jq ."
    ],
    "utterance": "Pretty-print a file where object and string keys/values are enclosed with single quotes instead of double quotes.",
    "expressions": [
      "tr \"'\" '\"' | jq ."
    ],
    "data": [
      {
        "input": "{ 'abc': { 'name': 'John', 'address': 'USA' }, 'xyz': { 'name': 'Robert', 'address': 'Canada' } }",
        "output": "{\n  \"abc\": {\n    \"name\": \"John\",\n    \"address\": \"USA\"\n  },\n  \"xyz\": {\n    \"name\": \"Robert\",\n    \"address\": \"Canada\"\n  }\n}"
      }
    ],
    "identifier": 48313302
  },
  {
    "context": [
      "For each line, retrieve annonce_id, titre_slug and photos in bash variables. Photos should be in an array, since it can contain 1 or more elements.",
      "jq -r '.[] | .annonce_id, .titre_slug, .photos'",
      "done < <(jq -r '.[] | .annonce_id, .titre_slug, (.photos | @tsv)' input.json)"
    ],
    "utterance": "For each object, get annonce_id and titre_slug as variables and photos as an array, to assign them in shell script.",
    "expressions": [
      ".[] | .annonce_id, .titre_slug, (.photos | @tsv)",
      ".[] | .annonce_id, .titre_slug, (.photos | @tsv)"
    ],
    "data": [
      {
        "input": [
          {
            "annonce_id": "123",
            "photos": [
              "url_01"
            ],
            "titre_slug": "slug1"
          },
          {
            "annonce_id": "456",
            "photos": [
              "url_11",
              "url_12"
            ],
            "titre_slug": "slug2"
          },
          {
            "annonce_id": "7890",
            "photos": [
              "url_31"
            ],
            "titre_slug": "slug3"
          },
          {
            "annonce_id": "1234",
            "photos": [
              "url_41"
            ],
            "titre_slug": "slug4"
          },
          {
            "annonce_id": "5678",
            "photos": [
              "url_51"
            ],
            "titre_slug": "slug5"
          },
          {
            "annonce_id": "90123",
            "photos": [
              "url_61"
            ],
            "titre_slug": "slug6"
          }
        ],
        "output": [
          "123",
          "slug1",
          "url_01",
          "456",
          "slug2",
          "url_11\turl_12",
          "7890",
          "slug3",
          "url_31",
          "1234",
          "slug4",
          "url_41",
          "5678",
          "slug5",
          "url_51",
          "90123",
          "slug6",
          "url_61"
        ]
      }
    ],
    "identifier": 48324463
  },
  {
    "context": [
      "Trying to format a json object into a proper format for DynamoDB in shell",
      "DynamoDB format, the one field that will be static is \"N\", but the numbers have to be formatted to string, which I may be able to do in the initial filter",
      "transform a JSON object {key1: value1, key2: value2, ...} into an object of the form: {key1: {\"N\": (value1|tostring)}, ...",
      "to_entries | map( {(.key): {N: (.value|tostring)}} ) | add;",
      "The solution to the problem (as I understand it) can then be written:\n\n    {Codes: {M: package}}"
    ],
    "utterance": "Transform an object with numeric values so that each key maps to an object with the key 'N' and the stringified value, wrapped in {Codes: {M: ...}}.",
    "expressions": [
      "def package: to_entries | map({(.key): {N: (.value|tostring)}}) | add; {Codes: {M: package}}",
      "to_entries | map({(.key): {N: (.value|tostring)}}) | add | {Codes: {M: .}}"
    ],
    "data": [
      {
        "input": {
          "200": 1728,
          "201": 288,
          "301": 214,
          "401": 104,
          "404": 12
        },
        "output": {
          "Codes": {
            "M": {
              "200": {
                "N": "1728"
              },
              "201": {
                "N": "288"
              },
              "301": {
                "N": "214"
              },
              "401": {
                "N": "104"
              },
              "404": {
                "N": "12"
              }
            }
          }
        }
      }
    ],
    "identifier": 48327037
  },
  {
    "context": [
      "The following should allow you to reduce the four calls to one:\r\n\r\n    [.Reservations[]\r\n     | .Instances[]\r\n     | (.Tags | { \"iname\": ( map ( select(.Value | contains(\"my-vm\")))[] | .Value ) } )\r\n        + ( { \"ip\": ( .NetworkInterfaces[].PrivateIpAddress) } ) ]\r\n    | group_by(.iname) | map({(.[0].iname): [.[] | .ip]})",
      "your jq query can simply be:\r\n\r\n    [.Reservations[].Instances[] |\r\n        {\r\n            (.Tags|from_entries.Name): [.NetworkInterfaces[].PrivateIpAddress]\r\n        }\r\n    ]"
    ],
    "utterance": "Group instances by their Name tag and list all associated private IP addresses for each instance.",
    "expressions": [
      "[.Reservations[] | .Instances[] | (.Tags | { \"iname\": ( map ( select(.Value | contains(\"my-vm\")))[] | .Value ) } ) + ( { \"ip\": ( .NetworkInterfaces[].PrivateIpAddress) } ) ] | group_by(.iname) | map({(.[0].iname): [.[] | .ip]})",
      "[.Reservations[].Instances[] | { (.Tags|from_entries.Name): [.NetworkInterfaces[].PrivateIpAddress] } ]"
    ],
    "data": [
      {
        "input": {
          "Reservations": [
            {
              "Instances": [
                {
                  "NetworkInterfaces": [
                    {
                      "PrivateIpAddress": "10.11.2.145"
                    },
                    {
                      "PrivateIpAddress": "10.11.1.146"
                    },
                    {
                      "PrivateIpAddress": "10.11.10.144"
                    }
                  ],
                  "Tags": [
                    {
                      "Key": "Name",
                      "Value": "my-vm-b"
                    }
                  ]
                },
                {
                  "NetworkInterfaces": [
                    {
                      "PrivateIpAddress": "10.11.1.9"
                    },
                    {
                      "PrivateIpAddress": "10.11.10.125"
                    },
                    {
                      "PrivateIpAddress": "10.11.2.85"
                    }
                  ],
                  "Tags": [
                    {
                      "Key": "Name",
                      "Value": "my-vm-a"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          {
            "my-vm-b": [
              "10.11.2.145",
              "10.11.1.146",
              "10.11.10.144"
            ]
          },
          {
            "my-vm-a": [
              "10.11.1.9",
              "10.11.10.125",
              "10.11.2.85"
            ]
          }
        ]
      }
    ],
    "identifier": 48322962
  },
  {
    "context": [
      "GetSubobject .b.x.y example.json",
      "The result from the function call would be emitted to stdout:\r\n\r\n    {\r\n      \"y\": {\r\n        \"j\": true,\r\n        \"k\": [\r\n          1,\r\n          2,\r\n          3\r\n        ]\r\n      }\r\n    }",
      "Note that the code `jq -r \"$Filter\" \"$File\"` would not give the desired answer. It would give:\r\n\r\n    { \"j\": true, \"k\": [1,2,3] }",
      "get subobject using jq ... hopefully in a less brute-force way that takes advantage of jq's capabilities without having to do pre-processing in Bash?",
      "jq -r \"$Prefix|to_entries|map(select(.key==\\\"$Suffix\\\"))|from_entries\" \"$File\"",
      "jq -r \"$Prefix| { $Suffix }\" \"$File\"",
      "local newroot=${1##*.}\njq -r \"{$newroot: $1}\" \"$2\"",
      "jq  '(null|path('$Filter')) as $path\n         | {($path[-1]): '$Filter'}' \"$File\""
    ],
    "utterance": "Given a key-path filter like .b.x.y, extract the object at that path and wrap it in an object keyed by the final path element as the result, so that { \"y\": <value_at_b.x.y> } is returned.",
    "expressions": [
      "{$newroot: $1}",
      "(null|path($Filter)) as $path | {($path[-1]): $Filter}"
    ],
    "data": [
      {
        "input": {
          "a": {
            "p": 1,
            "q": 2
          },
          "b": {
            "x": {
              "y": {
                "j": true,
                "k": [
                  1,
                  2,
                  3
                ]
              },
              "z": [
                4,
                5,
                6
              ]
            }
          }
        },
        "output": {
          "y": {
            "j": true,
            "k": [
              1,
              2,
              3
            ]
          }
        }
      }
    ],
    "identifier": 48332459
  },
  {
    "context": [
      "Now I want to filter PrivateIPAddress and InstanceType *only* if some key: value pair from the Tags[] array match. I am primarily looking for something like, if `select(.Value == \"qa\" and .Value == databaseteam)` match. In other words, based out of match criterion from the Tags array defined in the jq filter, I want to show PrivateIPAddress and InstanceType.",
      "I'll assume you meant\n\n    select(.Value == \"qa\" and .Key == \"environment\")\n",
      ".Instances[]\n| .PrivateIpAddress as $PIPA\n| .InstanceType as $IT\n| .Tags[]\n| select(.Value == \"qa\" and .Key == \"environment\")\n| [$PIPA, $IT]\n"
    ],
    "utterance": "Show PrivateIpAddress and InstanceType for instances where the Tags array contains an object with Value equal to \"qa\" and Key equal to \"environment\".",
    "expressions": [
      ".Instances[] | .PrivateIpAddress as $PIPA | .InstanceType as $IT | .Tags[] | select(.Value == \"qa\" and .Key == \"environment\") | [$PIPA, $IT]"
    ],
    "data": [
      {
        "input": {
          "Instances": [
            {
              "Monitoring": {
                "State": "disabled"
              },
              "PublicDnsName": "ec2-aa.compute-1.amazonaws.com",
              "State": {
                "Code": 16,
                "Name": "running"
              },
              "EbsOptimized": false,
              "LaunchTime": "2017-08-14T17:29:54.000Z",
              "PublicIpAddress": "aa",
              "PrivateIpAddress": "bb",
              "ProductCodes": [],
              "VpcId": "vpc-xx",
              "StateTransitionReason": "",
              "InstanceId": "i-f21c76a0",
              "ImageId": "ami-xx",
              "PrivateDnsName": "ip-bb.ec2.internal",
              "KeyName": "blah",
              "SecurityGroups": [
                {
                  "GroupName": "mygroup",
                  "GroupId": "sg-xx"
                }
              ],
              "ClientToken": "",
              "SubnetId": "subnet-xx",
              "InstanceType": "t2.micro",
              "NetworkInterfaces": [
                {
                  "Status": "in-use",
                  "MacAddress": "",
                  "SourceDestCheck": true,
                  "VpcId": "vpc-xx",
                  "Description": "",
                  "NetworkInterfaceId": "eni-xx",
                  "PrivateIpAddresses": [
                    {
                      "PrivateDnsName": "ip-bb.ec2.internal",
                      "PrivateIpAddress": "aa",
                      "Primary": true,
                      "Association": {
                        "PublicIp": "aa",
                        "PublicDnsName": "ec2-bb-1.amazonaws.com",
                        "IpOwnerId": "amazon"
                      }
                    }
                  ],
                  "PrivateDnsName": "ip-aa.ec2.internal",
                  "Attachment": {
                    "Status": "attached",
                    "DeviceIndex": 0,
                    "DeleteOnTermination": true,
                    "AttachmentId": "eni-attach-b11454cb",
                    "AttachTime": "2014-07-02T19:24:19.000Z"
                  },
                  "Groups": [
                    {
                      "GroupName": "mygroup",
                      "GroupId": "sg-xx"
                    }
                  ],
                  "Ipv6Addresses": [],
                  "OwnerId": "aa",
                  "PrivateIpAddress": "aa",
                  "SubnetId": "subnet-bb",
                  "Association": {
                    "PublicIp": "aa",
                    "PublicDnsName": "ec2-aa-1.amazonaws.com",
                    "IpOwnerId": "amazon"
                  }
                }
              ],
              "SourceDestCheck": true,
              "Placement": {
                "Tenancy": "default",
                "GroupName": "",
                "AvailabilityZone": "us-east-1e"
              },
              "Hypervisor": "xen",
              "BlockDeviceMappings": [
                {
                  "DeviceName": "/dev/sda1",
                  "Ebs": {
                    "Status": "attached",
                    "DeleteOnTermination": true,
                    "VolumeId": "vol-4fb6ed03",
                    "AttachTime": "2014-07-02T19:24:23.000Z"
                  }
                }
              ],
              "Architecture": "x86_64",
              "RootDeviceType": "ebs",
              "RootDeviceName": "/dev/sda1",
              "VirtualizationType": "hvm",
              "Tags": [
                {
                  "Value": "qa",
                  "Key": "environment"
                },
                {
                  "Value": "database",
                  "Key": "system"
                },
                {
                  "Value": "databaseteam",
                  "Key": "team"
                }
              ],
              "AmiLaunchIndex": 0
            }
          ],
          "ReservationId": "r-xx",
          "Groups": [],
          "OwnerId": "xx"
        },
        "output": [
          "bb",
          "t2.micro"
        ]
      }
    ],
    "identifier": 48050565
  },
  {
    "context": [
      "COUNT the number of pets per owner:",
      "jq -sc 'def count($k): group_by(.[$k])[] | length as $l | .[0] \n                           | .pets_count = $l \n                           | del(.pet_id, .pet, .litter); \n            count(\"owner_id\")' source.data",
      "GROUPS_BY(inputs; .owner_id)\n| (.[0] | owner) + {pets_count: count_distinct(.[]|.pet_id)}",
      "jq -s 'group_by(.owner_id) |  map({ owner_id: .[0].owner_id, count: map(.pet) | length})'"
    ],
    "utterance": "Count the number of pets for each owner, grouping by owner_id, and output owner_id, owner, age, and pets_count.",
    "expressions": [
      "def count($k): group_by(.[$k])[] | length as $l | .[0]\n| .pets_count = $l\n| del(.pet_id, .pet, .litter);\ncount(\"owner_id\")",
      "GROUPS_BY(inputs; .owner_id) | (.[0] | owner) + {pets_count: count_distinct(.[]|.pet_id)}",
      "group_by(.owner_id) | map({ owner_id: .[0].owner_id, owner: .[0].owner, age: .[0].age, pets_count: length })"
    ],
    "data": [
      {
        "input": [
          {
            "owner_id": 1,
            "owner": "Adams",
            "age": 25,
            "pet_id": 10,
            "pet": "Bella",
            "litter": 4
          },
          {
            "owner_id": 1,
            "owner": "Adams",
            "age": 25,
            "pet_id": 20,
            "pet": "Lucy",
            "litter": 2
          },
          {
            "owner_id": 2,
            "owner": "Baker",
            "age": 55,
            "pet_id": 30,
            "pet": "Daisy",
            "litter": 3
          },
          {
            "owner_id": 3,
            "owner": "Clark",
            "age": 40,
            "pet_id": 40,
            "pet": "Molly",
            "litter": 4
          },
          {
            "owner_id": 4,
            "owner": "Davis",
            "age": 31,
            "pet_id": 50,
            "pet": "Lola",
            "litter": 2
          },
          {
            "owner_id": 4,
            "owner": "Davis",
            "age": 31,
            "pet_id": 60,
            "pet": "Sadie",
            "litter": 4
          },
          {
            "owner_id": 4,
            "owner": "Davis",
            "age": 31,
            "pet_id": 70,
            "pet": "Luna",
            "litter": 3
          }
        ],
        "output": [
          {
            "owner_id": 1,
            "owner": "Adams",
            "age": 25,
            "pets_count": 2
          },
          {
            "owner_id": 2,
            "owner": "Baker",
            "age": 55,
            "pets_count": 1
          },
          {
            "owner_id": 3,
            "owner": "Clark",
            "age": 40,
            "pets_count": 1
          },
          {
            "owner_id": 4,
            "owner": "Davis",
            "age": 31,
            "pets_count": 3
          }
        ]
      }
    ],
    "identifier": 48321235
  },
  {
    "context": [
      "Here's my source data:",
      "[  { \"id\": \"27\", \"time\": \"2017-12-21 07:24:00\", \"service_name\": \"prices\", \"version\": \"61f4u8e\", \"event\": \"Success\" },   { \"id\": \"28\", \"time\": \"2017-12-21 07:23:00\", \"service_name\": \"prices\", \"version\": \"21c2f7d\", \"event\": \"Fail\" },   { \"id\": \"29\", \"time\": \"2017-12-21 07:21:00\", \"service_name\": \"cart\", \"version\": \"9ff24c4\", \"event\": \"Success\" } ]",
      "The result should look like this:",
      "[ { \"name\": \"cart\", \"data\": [ { \"date\": \"2017-12-21 07:21:00\", \"details\": { \"event\": \"Success\", \"version\": \"9ff24c4\" } } ] }, { \"name\": \"prices\", \"data\": [ { \"date\": \"2017-12-21 07:24:00\", \"details\": { \"event\": \"Success\", \"version\": \"61f4u8e\" } }, { \"date\": \"2017-12-21 07:23:00\", \"details\": { \"event\": \"Fail\", \"version\": \"21c2f7d\" } } ] } ]",
      "So, basically grouping by service_name and moving the other fields around a little.",
      "So far I've managed to group, but only one level:",
      "group_by(.service_name) | map({name: .[0].service_name, data: .})",
      "**`jq`** solution:",
      "jq '[group_by(.service_name)[] | .[0].service_name as $name | { name: $name, data: map({ date: .time, details: {event, version}}) }]' jsonfile"
    ],
    "utterance": "Group records by service_name and output objects with name as the service_name and data as arrays of {date: time, details: {event, version}}.",
    "expressions": [
      "[group_by(.service_name)[] | .[0].service_name as $name | { name: $name, data: map({ date: .time, details: {event, version}}) }]"
    ],
    "data": [
      {
        "input": [
          {
            "id": "27",
            "time": "2017-12-21 07:24:00",
            "service_name": "prices",
            "version": "61f4u8e",
            "event": "Success"
          },
          {
            "id": "28",
            "time": "2017-12-21 07:23:00",
            "service_name": "prices",
            "version": "21c2f7d",
            "event": "Fail"
          },
          {
            "id": "29",
            "time": "2017-12-21 07:21:00",
            "service_name": "cart",
            "version": "9ff24c4",
            "event": "Success"
          }
        ],
        "output": [
          {
            "name": "cart",
            "data": [
              {
                "date": "2017-12-21 07:21:00",
                "details": {
                  "event": "Success",
                  "version": "9ff24c4"
                }
              }
            ]
          },
          {
            "name": "prices",
            "data": [
              {
                "date": "2017-12-21 07:24:00",
                "details": {
                  "event": "Success",
                  "version": "61f4u8e"
                }
              },
              {
                "date": "2017-12-21 07:23:00",
                "details": {
                  "event": "Fail",
                  "version": "21c2f7d"
                }
              }
            ]
          }
        ]
      }
    ],
    "identifier": 48372018
  },
  {
    "context": [
      "I have the following JSON:\r\n\r\n        {\r\n            \"field1\":\"foo\",\r\n            \"array\":[\r\n                {\r\n                    child_field1:\"c1_1\",\r\n                    child_field2:\"c1_2\"\r\n                },\r\n                {\r\n                    child_field1:\"c2_1\",\r\n                    child_field2:\"c2_2\"\r\n                }\r\n             ]...\r\n        }\r\n\r\nand using ```jq```, I would like to return the following output, where the value of ```field1``` is repeated for every child element.:\r\n\r\n        foo,c1_1,c1_2\r\n        foo,c2_1,c2_2\r\n        ...",
      "jq -r '.array[] as $a | [.field1, $a.child_field1, $a.child_field2] | @csv'",
      "jq -r '.array[] as $a | \"\\(.field1),\\($a.child_field1),\\($a.child_field2)\"'",
      "jq -r '.field1 as $f1 | .array[] \r\n           | [$f1, .[]] \r\n           | join(\",\")' input.json",
      ".field1 as $f\n| .array[]\n| [$f, .[]]\n| @csv"
    ],
    "utterance": "Output each array element as a line containing the value of field1 followed by the child_field1 and child_field2 values from each array object, separated by commas.",
    "expressions": [
      ".field1 as $f | .array[] | [$f, .child_field1, .child_field2] | @csv",
      ".field1 as $f | .array[] | [$f, .child_field1, .child_field2] | join(\",\")",
      ".field1 as $f | .array[] | \"\u0005cf,$(.child_field1),$(.child_field2)\"",
      ".array[] as $a | [.field1, $a.child_field1, $a.child_field2] | @csv",
      ".array[] as $a | \"\\(.field1),\\($a.child_field1),\\($a.child_field2)\"",
      ".field1 as $f1 | .array[] | [$f1, .[]] | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "field1": "foo",
          "array": [
            {
              "child_field1": "c1_1",
              "child_field2": "c1_2"
            },
            {
              "child_field1": "c2_1",
              "child_field2": "c2_2"
            }
          ]
        },
        "output": [
          "foo,c1_1,c1_2",
          "foo,c2_1,c2_2"
        ]
      }
    ],
    "identifier": 48364608
  },
  {
    "context": [
      "However, sometimes I need to add an item with a name attribute that already exists in the response, I need to overwrite it\u2019s value with the new one I want to set. For example, I may want to change the value of 'item2' to `false`.",
      "I'm still unsure of how to add an item if it doesn't exist in the array (when it's finished looping over it).",
      "jq --slurpfile new_items new_objects.dat \\\n     '.objectList |= [ . + $new_items | group_by(.name)[] | add ]' apiResponse.json",
      "[\n  (((.objectList[] | select(.name == \"itemX\")) // {\"name\": \"item3\", \"value\": null}) | .value = false)\n  ,\n  (.objectList[] | select(.name != \"itemX\"))\n] |\n{\"objectList\": .}"
    ],
    "utterance": "Update an object in 'objectList' by name and replace its value if it exists, or add a new object with the specified name and value if it does not exist.",
    "expressions": [
      ".objectList |= [ . + $new_items | group_by(.name)[] | add ]",
      "[(((.objectList[] | select(.name == \"itemX\")) // {\"name\": \"item3\", \"value\": null}) | .value = false), (.objectList[] | select(.name != \"itemX\"))] | {\"objectList\": .}"
    ],
    "data": [
      {
        "input": {
          "objectList": [
            {
              "name": "item1",
              "value": false
            },
            {
              "name": "item2",
              "value": true
            },
            {
              "name": "item4",
              "value": true
            }
          ]
        },
        "output": {
          "objectList": [
            {
              "name": "item1",
              "value": true
            },
            {
              "name": "item2",
              "value": false
            },
            {
              "name": "item3",
              "value": true
            },
            {
              "name": "item4",
              "value": true
            }
          ]
        }
      },
      {
        "input": [
          {
            "name": "item1",
            "value": true
          },
          {
            "name": "item2",
            "value": false
          },
          {
            "name": "item3",
            "value": true
          }
        ]
      }
    ],
    "identifier": 48379728
  },
  {
    "context": [
      "I have two JSON objects:",
      "{ \"parameter1\": \"object1\", \"childs\": [ { \"id\": \"child1\", \"parameter-A\": \"value-A\" } ] }",
      "{ \"parameter2\": \"object2\", \"childs\": [ { \"id\": \"child1\", \"parameter-B\": \"value-B\" } ] }",
      "I need to merge the objects, but I don't want to get the containing arrays to be replaced, but also merged, i.e. added in case the id equals. This is what I need:",
      "{ \"parameter1\": \"object1\", \"parameter2\": \"object2\", \"childs\": [ { \"id\": \"child1\", \"parameter-A\": \"value-A\", \"parameter-B\": \"value-B\" } ] }",
      "I currently merge the two files with jq -s '.[0] * .[1]' file1 file2, but parameter-A is overwritten by parameter-B with the unwanted result where parameter-A is missing:",
      "{ \"parameter1\": \"object1\", \"parameter2\": \"object2\", \"childs\": [ { \"id\": \"child1\", \"parameter-B\": \"value-B\" } ] }",
      "The following filter will, I believe, produce the desired result in the particular case that has been presented, but the general requirements are unclear, so it may be necessary to make adjustments accordingly:",
      "def add_merge($one; $two):\n  def pairwise_add:\n    transpose\n    | map(if .[0].id == .[1].id then add else . end);\n  reduce ($one|keys_unsorted[]) as $k ($one+$two;\n     if ($one[$k]|type) == \"array\"\n     then .[$k] = ([$one[$k], $two[$k]] | pairwise_add)\n     else .\n     end);",
      "For the given pair of objects, the result is:\n\n    {\n      \"parameter1\": \"object1\",\n      \"childs\": [\n        {\n          \"id\": \"child1\",\n          \"parameter-A\": \"value-A\",\n          \"parameter-B\": \"value-B\"\n        }\n      ],\n      \"parameter2\": \"object2\"\n    }"
    ],
    "utterance": "Merge two objects so that arrays with objects sharing the same id have their objects merged by id instead of being replaced.",
    "expressions": [
      "def add_merge($one; $two):\n  def pairwise_add:\n    transpose\n    | map(if .[0].id == .[1].id then add else . end);\n  reduce ($one|keys_unsorted[]) as $k ($one+$two;\n     if ($one[$k]|type) == \"array\"\n     then .[$k] = ([$one[$k], $two[$k]] | pairwise_add)\n     else .\n     end);\nadd_merge(.[0]; .[1])"
    ],
    "data": [
      {
        "input": [
          {
            "parameter1": "object1",
            "childs": [
              {
                "id": "child1",
                "parameter-A": "value-A"
              }
            ]
          },
          {
            "parameter2": "object2",
            "childs": [
              {
                "id": "child1",
                "parameter-B": "value-B"
              }
            ]
          }
        ],
        "output": {
          "parameter1": "object1",
          "parameter2": "object2",
          "childs": [
            {
              "id": "child1",
              "parameter-A": "value-A",
              "parameter-B": "value-B"
            }
          ]
        }
      }
    ],
    "identifier": 48348722
  },
  {
    "context": [
      "The JSON included in the question is a JSON string (except that the initial double-quote is missing).  To convert it into a JSON object, you can use the `fromjson` filter, so you would write:\r\n \r\n     jq 'fromjson|.Resource'",
      "resource=$(echo ${resource} | jq \".\" | jq \".Resource\" | sed \"s|\\\"||g\")"
    ],
    "utterance": "Extract the value of the Resource key from a string containing a JSON object.",
    "expressions": [
      "fromjson | .Resource",
      ".Resource"
    ],
    "data": [
      {
        "input": "{\\\"Sid\\\":\\\"xxxxxxxx\\\",\\\"Effect\\\":\\\"Allow\\\",\\\"Principal\\\":{\\\"Service\\\":\\\"events.amazonaws.com\\\"},\\\"Action\\\":\\\"lambda:InvokeFunction\\\",\\\"Resource\\\":\\\"arn:aws:lambda:us-west-2:xxxxxxxx:function:xxxxxx\\\",\\\"Condition\\\":{\\\"ArnLike\\\":{\\\"AWS:SourceArn\\\":\\\"arn:aws:events:us-west-2:xxxxxx:rule/xxxxx\\\"}}}",
        "output": "\"arn:aws:lambda:us-west-2:xxxxxxxx:function:xxxxxx\""
      }
    ],
    "identifier": 48381878
  },
  {
    "context": [
      "when I do `http /endpoint/url | jq '.foo-bar', it gave the following error:",
      "it looks like `jq` thinks I'm trying to do arithmetic operation with `foo-bar`.",
      "How do I correctly form this kind of path?",
      "you need to put the field within quotes to let `jq` know that it is a single field `foo-bar` you are accessing and not as separate fields",
      "jq '.\"foo-bar\"'",
      "use the array access operator as `jq '[\"foo-bar\"]'`"
    ],
    "utterance": "Extract the value of the field named foo-bar, where the field name contains a dash.",
    "expressions": [
      ".[\"foo-bar\"]",
      ".\"foo-bar\""
    ],
    "data": [
      {
        "input": {
          "foo": 1,
          "bar": 2,
          "foo-bar": 3
        },
        "output": 3
      }
    ],
    "identifier": 48395816
  },
  {
    "context": [
      "\"cat file.json | jq --raw-output '.text' outputs abc\"",
      "\"What we are trying to achieve is json=$(<bash program> <captured JSON property>) message='{\"message\": \"$json\"}' where the {\"text\":\"abc\"} is sent to the Native Messaging host from client (Chromium app).\"",
      "\"How to use jq within the code at the former Answer to get the JSON property as a variable?\"",
      "Assuming that file.json contains the JSON as indicated, I believe all you will need is:",
      "json=$(jq '{message: .}' file.json)",
      "If you then echo \"$json\", the result will be:",
      "{",
      "  \"message\": {",
      "    \"text\": \"abc\"",
      "  }",
      "}"
    ],
    "utterance": "Wrap the entire input object as the value of a new object with the property name 'message'.",
    "expressions": [
      "jq '{message: .}'"
    ],
    "data": [
      {
        "input": {
          "text": "abc"
        },
        "output": {
          "message": {
            "text": "abc"
          }
        }
      }
    ],
    "identifier": 48385086
  },
  {
    "context": [
      "I have a file containing json lines that need to be verified for its validity based on the sequence of each json's flapping \"alert.status\" value.",
      "But since the sequence in each line is important, I don't think I can use group_by to look for duplicates (the group_by's result is sorted).",
      "Is there a way in jq to use group by all except two keys? (in this case \"status\" and the new key with incremental number).",
      "\"GROUPS_BY(inputs; del(.alert)) | select( changing(.alert.status) | not )\"",
      "def GROUPS_BY(stream; f): \n   reduce stream as $x ({};\n     ($x|f) as $s\n     | ($s|type) as $t\n     | (if $t == \"string\" then $s else ($s|tojson) end) as $y\n     | .[$t][$y] += [$x] )\n   | .[][]\n   ;",
      "def changing(f):\n  def c:\n    if length <= 1 then true\n    elif (.[0] | f) == (.[1] | f) then false\n    else .[1:] | c\n    end;\n  c ;"
    ],
    "utterance": "Identify groups of objects by all fields except alert.status, preserving input order, and return the groups where alert.status does not alternate in sequence.",
    "expressions": [
      "def GROUPS_BY(stream; f): \n   reduce stream as $x ({};\n     ($x|f) as $s\n     | ($s|type) as $t\n     | (if $t == \"string\" then $s else ($s|tojson) end) as $y\n     | .[$t][$y] += [$x] )\n   | .[][]\n   ;\ndef changing(f):\n  def c:\n    if length <= 1 then true\n    elif (.[0] | f) == (.[1] | f) then false\n    else .[1:] | c\n    end;\n  c ;\nGROUPS_BY(inputs; del(.alert)) | select( changing(.alert.status) | not )"
    ],
    "data": [
      {
        "input": [
          {
            "id": 123,
            "code": "foo",
            "severity": "Critical",
            "severityCode": 1,
            "property": {
              "priority": "top",
              "owner": "dev"
            },
            "alert": {
              "mgmt": "yes",
              "status": "On"
            }
          },
          {
            "id": 456,
            "code": "bar",
            "severity": "High",
            "severityCode": 2,
            "property": {
              "priority": "top",
              "owner": "dev"
            },
            "alert": {
              "mgmt": "yes",
              "status": "On"
            }
          },
          {
            "id": 123,
            "code": "foo",
            "severity": "Critical",
            "severityCode": 1,
            "property": {
              "priority": "top",
              "owner": "dev"
            },
            "alert": {
              "mgmt": "yes",
              "status": "Off"
            }
          },
          {
            "id": 456,
            "code": "bar",
            "severity": "High",
            "severityCode": 2,
            "property": {
              "priority": "top",
              "owner": "dev"
            },
            "alert": {
              "mgmt": "yes",
              "status": "Off"
            }
          },
          {
            "id": 123,
            "code": "foo",
            "severity": "Critical",
            "severityCode": 1,
            "property": {
              "priority": "top",
              "owner": "dev"
            },
            "alert": {
              "mgmt": "yes",
              "status": "On"
            }
          },
          {
            "id": 456,
            "code": "bar",
            "severity": "High",
            "severityCode": 2,
            "property": {
              "priority": "top",
              "owner": "dev"
            },
            "alert": {
              "mgmt": "yes",
              "status": "On"
            }
          }
        ]
      },
      {
        "input": [
          {
            "id": 123,
            "code": "foo",
            "severity": "Critical",
            "severityCode": 1,
            "property": {
              "priority": "top",
              "owner": "dev"
            },
            "alert": {
              "mgmt": "yes",
              "status": "On"
            }
          },
          {
            "id": 456,
            "code": "bar",
            "severity": "High",
            "severityCode": 2,
            "property": {
              "priority": "top",
              "owner": "dev"
            },
            "alert": {
              "mgmt": "yes",
              "status": "On"
            }
          },
          {
            "id": 123,
            "code": "foo",
            "severity": "Critical",
            "severityCode": 1,
            "property": {
              "priority": "top",
              "owner": "dev"
            },
            "alert": {
              "mgmt": "yes",
              "status": "On"
            }
          },
          {
            "id": 456,
            "code": "bar",
            "severity": "High",
            "severityCode": 2,
            "property": {
              "priority": "top",
              "owner": "dev"
            },
            "alert": {
              "mgmt": "yes",
              "status": "Off"
            }
          },
          {
            "id": 123,
            "code": "foo",
            "severity": "Critical",
            "severityCode": 1,
            "property": {
              "priority": "top",
              "owner": "dev"
            },
            "alert": {
              "mgmt": "yes",
              "status": "Off"
            }
          },
          {
            "id": 456,
            "code": "bar",
            "severity": "High",
            "severityCode": 2,
            "property": {
              "priority": "top",
              "owner": "dev"
            },
            "alert": {
              "mgmt": "yes",
              "status": "Off"
            }
          }
        ]
      }
    ],
    "identifier": 48105506
  },
  {
    "context": [
      "I hava a file:\r\n\r\n    {\r\n\t   &quot;test1&quot;: [\r\n\t\t    &quot;test_a&quot;,\r\n\t\t    &quot;test_b&quot;,\r\n\t\t    &quot;test_c&quot;\r\n\t   ]\r\n    }\r\n\r\n\r\nI am trying to extract the text that exists between `&quot;test1&quot;: [` and `]`",
      "The jq utility is designed for what you're trying to do:\r\n\r\n    cat test | jq '[\"test\"]'",
      "Simply with **`jq`** tool:\r\n\r\n    jq -r '.test1[]' testfile\r\nThe output:\r\n\r\n    test_a\r\n    test_b\r\n    test_c"
    ],
    "utterance": "Return each value from the test1 array as separate text lines.",
    "expressions": [
      ".test1[]",
      ".test1[] | ."
    ],
    "data": [
      {
        "input": {
          "test1": [
            "test_a",
            "test_b",
            "test_c"
          ]
        },
        "output": [
          "test_a",
          "test_b",
          "test_c"
        ]
      }
    ],
    "identifier": 48407471
  },
  {
    "context": [
      "I want to list all values in form of string `*.md` no matter where they occur. How to achieve this in `jq`",
      "Here&#39;s a solution that scans for all *.md strings:",
      "jq -r &#39;.. | strings | select(endswith(&quot;.md&quot;))&#39;",
      "Output:",
      "index.md",
      "Aforeword.md",
      "ch001.md",
      "ch002.md"
    ],
    "utterance": "Extract all string values ending with .md regardless of nesting level or location in the data.",
    "expressions": [
      ".. | strings | select(endswith(\".md\"))",
      ".. | strings | select(test(\"\\.md$\"))",
      ".. | strings | select(test(\"\\.md$\"; \"i\"))"
    ],
    "data": [
      {
        "input": [
          {
            "Home Page": "index.md"
          },
          {
            "Chapters": [
              {
                "Foreword": "Aforeword.md"
              },
              {
                "Chap1": "ch001.md"
              },
              {
                "Chap2": "ch002.md"
              }
            ]
          }
        ],
        "output": [
          "index.md",
          "Aforeword.md",
          "ch001.md",
          "ch002.md"
        ]
      }
    ],
    "identifier": 48410387
  },
  {
    "context": [
      "But how to express \"change keyA by value A or add keyA=>valueA\" to the conf file ?",
      "jq --arg data \"$(paste -d':' <(printf \"%s\\n\" \"${!conf[@]}\") <(printf \"%s\\n\" \"${conf[@]}\") )\" \\\n   '. as $conf | map($data | split(\"\\n\")[] \n    | split(\":\") | {(.[0]) : .[1]}) \n    | add | $conf + .' conf.json > conf.tmp && mv conf.tmp conf.json"
    ],
    "utterance": "Update a file so each key is set to a given value, overwriting or adding keys as needed.",
    "expressions": [
      ". as $conf | map($data | split(\"\\n\")[] | split(\":\") | {(.[0]) : .[1]}) | add | $conf + ."
    ],
    "data": [
      {
        "input": {
          "status": "running",
          "minFrom": "2018-01-23",
          "maxTo": "2018-01-24",
          "nextTo": "2018-01-23",
          "nextFrom": "2018-01-22"
        },
        "output": {
          "status": "finished",
          "minFrom": "2018-01-23",
          "maxTo": "2018-01-24",
          "nextTo": "2018-01-24",
          "nextFrom": "2018-01-22",
          "result": "true"
        }
      }
    ],
    "identifier": 48423303
  },
  {
    "context": [
      "How can I use `jq` to get all the `username` values?",
      "$ jq -r '[].username' my_file.json"
    ],
    "utterance": "Extract the username field from each object in an array.",
    "expressions": [
      ".[].username"
    ],
    "data": [
      {
        "input": [
          {
            "username": "jdoe",
            "name": "John Doe"
          },
          {
            "username": "jadoe",
            "name": "Jane Doe"
          }
        ],
        "output": [
          "jdoe",
          "jadoe"
        ]
      }
    ],
    "identifier": 48426052
  },
  {
    "context": [
      "Here, I am unable to figure out how to extract the keys without passing in the exact keyname. Please help me, thanks!",
      "jq -r '.data | to_entries[] | [(.key|ascii_upcase), .value] | @tsv' data.json"
    ],
    "utterance": "List all keys within the 'data' object, converting each key to uppercase.",
    "expressions": [
      ".data | keys[] | ascii_upcase"
    ],
    "identifier": 48436391
  },
  {
    "context": [
      "but how to ignore SEC/PRI with \"0\" and get output in form:\n\n    PLATFORM:p1, ID:5, SEC:20\n    PLATFORM:p2, ID:6, PRI:10",
      "jq -c 'def del_empty($k): if (.[$k]|tonumber > 0) then . else del(.[$k]) end;\n      .[] | {PLATFORM: .platform, ID: .id, PRI: .pri, SEC: .sec}\n      | del_empty(\"PRI\")\n      | del_empty(\"SEC\")'",
      "The formatting could be done with `@tsv` by converting the data to an array, e.g.:\n\n**filter.jq**\n\n    .[]                                        | \n    if (.sec == \"0\") then del(.sec) else . end | \n    if (.pri == \"0\") then del(.pri) else . end | \n    to_entries                                 |\n    map(\"\\(.key | ascii_upcase):\\(.value)\")    |\n    @tsv",
      "Output:\n\n    PLATFORM:p1\tID:5\tSEC:20\n    PLATFORM:p2\tID:6\tPRI:10"
    ],
    "utterance": "Select each object and output platform and id, excluding pri and sec if their value is \"0\", and display the keys in uppercase label:value format separated by commas or tabs.",
    "expressions": [
      ".[] | {PLATFORM: .platform, ID: .id, PRI: .pri, SEC: .sec} | select(.PRI != \"0\") + select(has(\"PUB\")) | select(.SEC != \"0\") + select(has(\"SEC\"))",
      ".[] | if (.sec == \"0\") then del(.sec) else . end | if (.pri == \"0\") then del(.pri) else . end | to_entries | map(\"\u0001(.key | ascii_upcase):\u0001(.value)\") | @tsv",
      "def del_empty($k): if (.[$k]|tonumber > 0) then . else del(.[$k]) end; .[] | {PLATFORM: .platform, ID: .id, PRI: .pri, SEC: .sec} | del_empty(\"PRI\") | del_empty(\"SEC\")"
    ],
    "data": [
      {
        "input": [
          {
            "platform": "p1",
            "id": "5",
            "pri": "0",
            "sec": "20"
          },
          {
            "platform": "p2",
            "id": "6",
            "pri": "10",
            "sec": "0"
          }
        ],
        "output": [
          "PLATFORM:p1\tID:5\tSEC:20",
          "PLATFORM:p2\tID:6\tPRI:10"
        ]
      }
    ],
    "identifier": 48384783
  },
  {
    "context": [
      "I have a json similar to the following:",
      "{\n    \"_source\" : {\n        \"index-pattern\" : {\n            \"fields\" : \"\"\n        }\n    }\n}",
      "I'm trying to modify fields, but chaining the . identity operator, such as '`jq ._source.[\"index-pattern\"].fields`' produces the following error:",
      "You could write:",
      "    ._source | .[\"index-pattern\"].fields",
      "or even:",
      "    ._source[\"index-pattern\"].fields"
    ],
    "utterance": "Access the value of the \"fields\" key inside the \"index-pattern\" object, which is nested under the \"_source\" key.",
    "expressions": [
      "._source | .[\"index-pattern\"].fields",
      "._source[\"index-pattern\"].fields"
    ],
    "data": [
      {
        "input": {
          "_source": {
            "index-pattern": {
              "fields": ""
            }
          }
        },
        "output": ""
      }
    ],
    "identifier": 48450533
  },
  {
    "context": [
      "set an environment variable called URL, ping that URL and add it to the json-- if 0, update another json field to SUCCESS, else update to FAILED.",
      "Here is are the files:\r\n\r\ninfo.json:\r\n\r\n    {\r\n     &quot;name&quot;: &quot;PingTest&quot;,&quot;,\r\n     &quot;metrics&quot;: [\r\n    {\r\n      &quot;event_type&quot;: &quot;PingResult&quot;,\r\n      &quot;provider&quot;: &quot;test&quot;,\r\n      &quot;providerUrl&quot;: &quot;URL&quot;,\r\n      &quot;providerResult&quot;: &quot;RESULT&quot;\r\n    }\r\n    ]\r\n    }",
      "jq -c \\\r\n   --arg url \"$URL\" \\\r\n   --arg result \"$result\" \\\r\n   '.metrics[].providerUrl |= $url | .metrics[].providerResult |= $result' info.json"
    ],
    "utterance": "Update the providerUrl and providerResult fields of all objects in the metrics array: set providerUrl to the URL variable, and providerResult to either SUCCESS or FAILED based on a shell variable.",
    "expressions": [
      ".metrics[].providerUrl |= $url | .metrics[].providerResult |= $result"
    ],
    "data": [
      {
        "input": {
          "name": "PingTest",
          "metrics": [
            {
              "event_type": "PingResult",
              "provider": "test",
              "providerUrl": "URL",
              "providerResult": "RESULT"
            }
          ]
        },
        "output": {
          "name": "PingTest",
          "metrics": [
            {
              "event_type": "PingResult",
              "provider": "test",
              "providerUrl": "www.dksmfdkf.com",
              "providerResult": "FAILED"
            }
          ]
        }
      }
    ],
    "identifier": 48505413
  },
  {
    "context": [
      "How can I use jq to search for \"name\" fields that start with an underscore (like `_RDS_PASSWORD`) and remove the leading underscore (so it becomes `RDS_PASSWORD`)",
      "How can I use jq for \"name\" fields that start with an underscore (like `_RDS_PASSWORD`) and pass the value of the value `cGFzc3dvcmQK` to be decoded via base64?",
      "Input:\n    [ \n      { \n        \"name\": \"RDS_DB_NAME\", \n        \"value\": \"rds_db_name\" \n      }, \n      { \n        \"name\": \"RDS_HOSTNAME\", \n        \"value\": \"rds_hostname\" \n      }, \n      { \n        \"name\": \"RDS_PORT\", \n        \"value\": \"1234\" \n      }, \n      { \n        \"name\": \"RDS_USERNAME\", \n        \"value\": \"rds_username\" \n      }, \n      { \n        \"name\": \"_RDS_PASSWORD\", \n        \"value\": \"cGFzc3dvcmQK\" \n      } \n    ]",
      "Desired output:\n    [ \n      { \n        \"name\": \"RDS_DB_NAME\", \n        \"value\": \"rds_db_name\" \n      }, \n      { \n        \"name\": \"RDS_HOSTNAME\", \n        \"value\": \"rds_hostname\" \n      }, \n      { \n        \"name\": \"RDS_PORT\", \n        \"value\": \"1234\" \n      }, \n      { \n        \"name\": \"RDS_USERNAME\", \n        \"value\": \"rds_username\" \n      }, \n      { \n        \"name\": \"RDS_PASSWORD\", \n        \"value\": \"password\" \n      } \n    ]",
      "Q1\nwalk( if type==\"object\" and has(\"name\") and .name[0:1] == \"_\"\n      then .name |= .[1:]\n      else . \n      end)",
      "Q2\n.. | objects | select(has(\"name\") and .name[0:1] == \"_\") | .value",
      "If you are certain that the encoded string was a UTF-8 string, you could use jq's @base64d"
    ],
    "utterance": "For each object with a name starting with an underscore, remove the leading underscore from the name and decode its value field from base64; leave other objects unchanged.",
    "expressions": [
      "map(if .name[0:1] == \"_\" then .name |= .[1:] | .value |= @base64d else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "RDS_DB_NAME",
            "value": "rds_db_name"
          },
          {
            "name": "RDS_HOSTNAME",
            "value": "rds_hostname"
          },
          {
            "name": "RDS_PORT",
            "value": "1234"
          },
          {
            "name": "RDS_USERNAME",
            "value": "rds_username"
          },
          {
            "name": "_RDS_PASSWORD",
            "value": "cGFzc3dvcmQK"
          }
        ],
        "output": [
          {
            "name": "RDS_DB_NAME",
            "value": "rds_db_name"
          },
          {
            "name": "RDS_HOSTNAME",
            "value": "rds_hostname"
          },
          {
            "name": "RDS_PORT",
            "value": "1234"
          },
          {
            "name": "RDS_USERNAME",
            "value": "rds_username"
          },
          {
            "name": "RDS_PASSWORD",
            "value": "password"
          }
        ]
      }
    ],
    "identifier": 48412767
  },
  {
    "context": [
      "But what I want is this",
      "{\r\n  \"development\": {\r\n    \"us-east-1\": {},\r\n    \"us-west-2\": {}\r\n  },\r\n  \"stage\": {\r\n    \"us-east-1\": {},\r\n    \"us-west-2\": {}\r\n  },\r\n  \"production\": {\r\n    \"us-east-1\": {},\r\n    \"us-west-2\": {}\r\n  }\r\n}",
      "The following script produces the desired result, and should be fairly robust:\r\n    \r\n    jq -n --slurpfile e <(for e in \"${environments[@]}\" ; do echo \"\\\"$e\\\"\"; done) \\\r\n       --slurpfile r <(for r in \"${regions[@]}\" ; do echo \"\\\"$r\\\"\" ; done) \\\r\n       '($r | map ({(.): {}}) | add) as $regions\r\n         | [{($e[]): $regions}] | add'"
    ],
    "utterance": "Build a nested object with environment names as top-level keys and region names as subkeys, each mapping to empty objects, using arrays of environments: ['development', 'stage', 'production'] and regions: ['us-east-1', 'us-west-2'].",
    "expressions": [
      "jq -n --slurpfile e <(for e in \"${environments[@]}\" ; do echo \"\\\"$e\\\"\"; done) \\\n   --slurpfile r <(for r in \"${regions[@]}\" ; do echo \"\\\"$r\\\"\" ; done) \\\n   '($r | map ({(.): {}}) | add) as $regions | [{($e[]): $regions}] | add'"
    ],
    "data": [
      {
        "input": {
          "environments": [
            "development",
            "stage",
            "production"
          ],
          "regions": [
            "us-east-1",
            "us-west-2"
          ]
        },
        "output": {
          "development": {
            "us-east-1": {},
            "us-west-2": {}
          },
          "stage": {
            "us-east-1": {},
            "us-west-2": {}
          },
          "production": {
            "us-east-1": {},
            "us-west-2": {}
          }
        }
      }
    ],
    "identifier": 48512598
  },
  {
    "context": [
      "And I want to export each of these key-value pairs as environment variables, how to do it via shell script? So for example, when I write on the terminal, `echo $hello1`, `world1` should be printed and similarly for other key-value pairs? Note: The above JSON is present in a variable called `$values` and not in a file.",
      "for s in $(echo $values | jq -r \"to_entries|map(\\\"\\(.key)=\\(.value|tostring)\\\")|.[]\" ); do\n    export $s\n done",
      "eval \"export $(printf \"%s\\n\" \"$values\" | jq -r 'to_entries | map(\"\\(.key)=\\(.value)\") | @sh')\";"
    ],
    "utterance": "Export each key-value pair from the object stored in the shell variable $values as environment variables so that the key becomes the variable name and the value its corresponding value.",
    "expressions": [
      ". as object | to_entries | map(\"\u0001.key)=\u0001.value)\") | .[]",
      "to_entries | map(\"\u0001.key)=\u0001.value)\") | @sh",
      "to_entries | map(\"\u0001.key)=\u0001.value|tostring)\") | .[]",
      "keys[] as $k | \"export \\\u0001.k)=\\(.[$k])\""
    ],
    "data": [
      {
        "input": {
          "hello1": "world1",
          "testk": "testv"
        },
        "output": [
          "export hello1=world1",
          "export testk=testv"
        ]
      }
    ],
    "identifier": 48512914
  },
  {
    "context": [
      "and would like to calculate the average of all values under:  `\"name\" : \"avg(total_response_time)\"` for each `identifier`iteratively.",
      "jq -r '\n    .[].stats.data[]\n    | (.identifier.values[]) as $identifier\n    | (.metric[]\n       | select(.name == \"avg(total_response_time)\")\n       | .values\n      ) as $values\n    | [$identifier, ($values | add) / ($values | length)]\n    | @tsv\n    ' <test.json",
      "def average(s): \n  reduce s as $x (null; .sum += $x | .n += 1)\n  | if . == null then null else .sum / .n end;",
      ".Response.stats.data[]\n| {id: (.identifier.values),\n   average: average(.metric[]\n     | select(.name == \"avg(total_response_time)\")\n     | .values[]) }"
    ],
    "utterance": "For each identifier, compute the average of all numbers in the metric where the name is \"avg(total_response_time)\".",
    "expressions": [
      ".[] .stats.data[] | (.identifier.values[]) as $identifier | (.metric[] | select(.name == \"avg(total_response_time)\") | .values ) as $values | [$identifier, ($values | add) / ($values | length)] | @tsv",
      "def average(s): reduce s as $x (null; .sum += $x | .n += 1) | if . == null then null else .sum / .n end; .Response.stats.data[] | {id: (.identifier.values), average: average(.metric[] | select(.name == \"avg(total_response_time)\") | .values[])}"
    ],
    "data": [
      {
        "input": {
          "Response": {
            "TimeUnit": [
              1516298400000,
              1516302000000,
              1516305600000,
              1516309200000,
              1516312800000,
              1516316400000
            ],
            "metaData": {
              "errors": [],
              "notices": [
                "Source:Postgres",
                "Limit applied: 14400",
                "PG Host:ruappg0ro.apigeeks.net",
                "Metric with Avg of total_response_time was requested. For this a global avg was also computed with name global-avg-total_response_time",
                "query served by:88bec25a-ef48-464e-b41d-e447e3beeb88",
                "Table used: edge.api.faxgroupusenondn012.agg_api"
              ]
            },
            "stats": {
              "data": [
                {
                  "identifier": {
                    "names": [
                      "apiproxy"
                    ],
                    "values": [
                      "test"
                    ]
                  },
                  "metric": [
                    {
                      "env": "test",
                      "name": "sum(message_count)",
                      "values": [
                        28.0,
                        129.0,
                        24.0,
                        20.0,
                        71.0,
                        30.0
                      ]
                    },
                    {
                      "env": "test",
                      "name": "avg(total_response_time)",
                      "values": [
                        312.57142857142856,
                        344.2480620155039,
                        374.2083333333333,
                        381.1,
                        350.67605633802816,
                        363.8
                      ]
                    },
                    {
                      "env": "test",
                      "name": "sum(is_error)",
                      "values": [
                        0.0,
                        0.0,
                        0.0,
                        0.0,
                        0.0,
                        0.0
                      ]
                    },
                    {
                      "env": "test",
                      "name": "global-avg-total_response_time",
                      "values": [
                        349.5860927152318
                      ]
                    }
                  ]
                },
                {
                  "identifier": {
                    "names": [
                      "apiproxy"
                    ],
                    "values": [
                      "test2"
                    ]
                  },
                  "metric": [
                    {
                      "env": "test",
                      "name": "sum(message_count)",
                      "values": [
                        0.0,
                        0.0,
                        0.0,
                        16.0,
                        137.0,
                        100.0
                      ]
                    },
                    {
                      "env": "test",
                      "name": "avg(total_response_time)",
                      "values": [
                        0.0,
                        0.0,
                        0.0,
                        237.4375,
                        198.02189781021897,
                        189.44
                      ]
                    },
                    {
                      "env": "test",
                      "name": "sum(is_error)",
                      "values": [
                        0.0,
                        0.0,
                        0.0,
                        16.0,
                        137.0,
                        100.0
                      ]
                    },
                    {
                      "env": "test",
                      "name": "global-avg-total_response_time",
                      "values": [
                        197.12252964426878
                      ]
                    }
                  ]
                },
                {
                  "identifier": {
                    "names": [
                      "apiproxy"
                    ],
                    "values": [
                      "appdyn"
                    ]
                  },
                  "metric": [
                    {
                      "env": "test",
                      "name": "sum(message_count)",
                      "values": [
                        0.0,
                        0.0,
                        0.0,
                        11.0,
                        137.0,
                        98.0
                      ]
                    },
                    {
                      "env": "test",
                      "name": "avg(total_response_time)",
                      "values": [
                        0.0,
                        0.0,
                        0.0,
                        170.0,
                        161.57664233576642,
                        149.16326530612244
                      ]
                    },
                    {
                      "env": "test",
                      "name": "sum(is_error)",
                      "values": [
                        0.0,
                        0.0,
                        0.0,
                        11.0,
                        137.0,
                        98.0
                      ]
                    },
                    {
                      "env": "test",
                      "name": "global-avg-total_response_time",
                      "values": [
                        157.0081300813008
                      ]
                    }
                  ]
                },
                {
                  "identifier": {
                    "names": [
                      "apiproxy"
                    ],
                    "values": [
                      "AppDyn"
                    ]
                  },
                  "metric": [
                    {
                      "env": "test",
                      "name": "sum(message_count)",
                      "values": [
                        0.0,
                        0.0,
                        0.0,
                        3.0,
                        0.0,
                        0.0
                      ]
                    },
                    {
                      "env": "test",
                      "name": "avg(total_response_time)",
                      "values": [
                        0.0,
                        0.0,
                        0.0,
                        39.333333333333336,
                        0.0,
                        0.0
                      ]
                    },
                    {
                      "env": "test",
                      "name": "sum(is_error)",
                      "values": [
                        0.0,
                        0.0,
                        0.0,
                        0.0,
                        0.0,
                        0.0
                      ]
                    },
                    {
                      "env": "test",
                      "name": "global-avg-total_response_time",
                      "values": [
                        39.333333333333336
                      ]
                    }
                  ]
                }
              ]
            }
          }
        },
        "output": [
          [
            "test",
            354.43398004304896
          ],
          [
            "test2",
            104.14989963503649
          ],
          [
            "appdyn",
            80.1233179403148
          ],
          [
            "AppDyn",
            6.555555555555556
          ]
        ]
      }
    ],
    "identifier": 48332761
  },
  {
    "context": [
      "I have the binary representation of an UTF-8 string as an array of numeric values, each in the range of 0..255.",
      "How to convert that array into the string using `jq`?",
      "For instance, the string \"Hi, \u041c\u0438\u0440!\" goes into [72,105,44,32,208,156,208,184,209,128,33] byte array, while its codepoints are [72,105,44,32,1052,1080,1088,33]. `implode` of the latter gives the original string, while `implode` of the former gives \"Hi,&#208;&#208;&#184;&#209;!\" or something like that.",
      "def btostring:\n      if length == 0 then \"\"\n    \n      elif .[0] >= 240 then\n         ([((((.[0] - 240) * 64) + (.[1] - 128)) * 64 + (.[2] - 128)) * 64 + (.[3] - 128)]\n          | implode) + (.[4:] | btostring)\n    \n      elif .[0] >= 224 then\n         ([  ((.[0] - 224) * 64 +  (.[1] - 128)) * 64 + (.[2] - 128)]\n          | implode) + (.[3:] | btostring)\n    \n      elif .[0] >= 128 then\n         ([  (.[0] - 192)  * 64 +  (.[1] - 128) ]\n          | implode) + (.[2:] | btostring)\n    \n      else  (.[0:1] | implode ) + (.[1:] | btostring)\n      end;",
      "def hi: [72,105,44,32,208,156,208,184,209,128,33] ;\n\nhi | btostring",
      "Output (using `jq -r`):\n\nHi, \u041c\u0438\u0440!",
      "[foreach .[] as $item (\n\t\t[0, 0]\n\t\t;\n\t\tif .[0] > 0 then [.[0] - 1, .[1] * 64 + ($item % 64)]\n\t\telif $item >= 240 then [3, $item % 8]\n\t\telif $item >= 224 then [2, $item % 16]\n\t\telif $item >= 192 then [1, $item % 32]\n\t\telif $item < 128 then [0, $item]\n\t\telse error(\"Malformed UTF-8 bytes\")\n\t\tend\n\t\t;\n\t\tif .[0] == 0 then .[1] else empty end\n\t)] | implode",
      "def btostring:\n\tif type != \"array\" then .\n\telif length == 0 then \"\"\n\telif .[0] >= 245 then\n\t\t(.[0:1] | implode ) + (.[1:] | btostring)\n\telif .[0] >= 240 then\n\t\tif length >= 4 and .[1] >= 128 and .[2] >= 128 and .[3] >= 128 then\n\t\t\t([((((.[0] - 240) * 64) + (.[1] - 128)) * 64 + (.[2] - 128)) * 64 + (.[3] - 128)] | implode) + (.[4:] | btostring)\n\t\telse\n\t\t\t(.[0:1] | implode ) + (.[1:] | btostring)\n\t\tend\n\telif .[0] >= 224 then\n\t\tif length >= 3 and .[1] >= 128 and .[2] >= 128 then\n\t\t\t([  ((.[0] - 224) * 64  + (.[1] - 128)) * 64 + (.[2] - 128)] | implode) + (.[3:] | btostring)\n\t\telse\n\t\t\t(.[0:1] | implode ) + (.[1:] | btostring)\n\t\tend\n\telif .[0] >= 194 then\n\t\tif length >= 2 and .[1] >= 128 then\n\t\t\t([   (.[0] - 192) * 64  + (.[1] - 128) ] | implode) + (.[2:] | btostring)\n\t\telse\n\t\t\t(.[0:1] | implode ) + (.[1:] | btostring)\n\t\tend\n\telse\n\t\t(.[0:1] | implode ) + (.[1:] | btostring)\n\tend;"
    ],
    "utterance": "Convert an array of bytes representing a UTF-8 encoded string, such as [72,105,44,32,208,156,208,184,209,128,33], to its decoded string form, preserving all Unicode characters.",
    "expressions": [
      "def btostring:\n  if length == 0 then \"\"\n  elif .[0] >= 240 then ([((((.[0] - 240) * 64) + (.[1] - 128)) * 64 + (.[2] - 128)) * 64 + (.[3] - 128)] | implode) + (.[4:] | btostring)\n  elif .[0] >= 224 then ([ ((.[0] - 224) * 64 +  (.[1] - 128)) * 64 + (.[2] - 128)] | implode) + (.[3:] | btostring)\n  elif .[0] >= 128 then ([ (.[0] - 192)  * 64 +  (.[1] - 128) ] | implode) + (.[2:] | btostring)\n  else  (.[0:1] | implode ) + (.[1:] | btostring)\n  end ;",
      "[foreach .[] as $item (\n    [0, 0]\n    ;\n    if .[0] > 0 then [.[0] - 1, .[1] * 64 + ($item % 64)]\n    elif $item >= 240 then [3, $item % 8]\n    elif $item >= 224 then [2, $item % 16]\n    elif $item >= 192 then [1, $item % 32]\n    elif $item < 128 then [0, $item]\n    else error(\"Malformed UTF-8 bytes\")\n    end\n    ;\n    if .[0] == 0 then .[1] else empty end\n)] | implode",
      "def btostring:\n  if type != \"array\" then .\n  elif length == 0 then \"\"\n  elif .[0] >= 245 then (.[0:1] | implode ) + (.[1:] | btostring)\n  elif .[0] >= 240 then\n    if length >= 4 and .[1] >= 128 and .[2] >= 128 and .[3] >= 128 then ([((((.[0] - 240) * 64) + (.[1] - 128)) * 64 + (.[2] - 128)) * 64 + (.[3] - 128)] | implode) + (.[4:] | btostring)\n    else (.[0:1] | implode ) + (.[1:] | btostring)\n    end\n  elif .[0] >= 224 then\n    if length >= 3 and .[1] >= 128 and .[2] >= 128 then ([  ((.[0] - 224) * 64  + (.[1] - 128)) * 64 + (.[2] - 128)] | implode) + (.[3:] | btostring)\n    else (.[0:1] | implode ) + (.[1:] | btostring)\n    end\n  elif .[0] >= 194 then\n    if length >= 2 and .[1] >= 128 then ([   (.[0] - 192) * 64  + (.[1] - 128) ] | implode) + (.[2:] | btostring)\n    else (.[0:1] | implode ) + (.[1:] | btostring)\n    end\n  else (.[0:1] | implode ) + (.[1:] | btostring)\n  end;"
    ],
    "data": [
      {
        "input": [
          72,
          105,
          44,
          32,
          208,
          156,
          208,
          184,
          209,
          128,
          33
        ],
        "output": "Hi, \u041c\u0438\u0440!"
      }
    ],
    "identifier": 48425781
  },
  {
    "context": [
      "My question is: how to make JQ output in a table format, replacing absent values with 0?",
      "The desired output of JQ, for the given sample is a table where on horizontal you have the date from key_as_string (in this case from 18.01.2018 to 25.01.2018) and on vertical the all the asset keys (i.e. ASSET-DD583, ASSET-DD568, etc). The table is populated with totalMaxUptime.value for every corresponding date and if the date is not present in the result, a \"0\" value should be put instead:",
      "\"In the following, I've used `@tsv` so the output can more easily be seen as a table, but you might want to use `@csv`.",
      "The tricky part here is to put the 0s in the right place.  Creating a JSON \"dictionary\" (i.e. JSON object) makes it easy. Here, `normalize` takes advantage of the fact that jq will honor the order in which keys are added to an object.",
      "([\"Asset\"] + dates),",
      "(.aggregations.overall.buckets[].agg_per_name.buckets[]",
      "| .key as $asset",
      "| .totalMaxUptime_perDays.buckets",
      "| map( { (.key_as_string | sub(\"T.*\";\"\") ): .totalMaxUptime.value } )",
      "| add",
      "| normalize",
      "| [$asset] + [.[]]",
      ")",
      "| @tsv",
      "You might want to modify the above so that `dates` is computed from the data.",
      "Parentheses around `$in[$k] // 0` have been added."
    ],
    "utterance": "Output a table with asset keys as rows and dates as columns, filling missing date values with 0 for each asset, with cells showing totalMaxUptime.value for each asset and date.",
    "expressions": [
      "def dates:\n  [\"2018-01-18\", \"2018-01-19\", \"2018-01-20\", \"2018-01-21\", \"2018-01-22\", \"2018-01-23\", \"2018-01-24\", \"2018-01-25\"];\n\ndef normalize:\n  . as $in \n  | reduce dates[] as $k ({}; .[$k] = ($in[$k] // 0));\n\n([\"Asset\"] + dates),\n(.aggregations.overall.buckets[].agg_per_name.buckets[]\n | .key as $asset\n | .totalMaxUptime_perDays.buckets\n | map( { (.key_as_string | sub(\"T.*\";\"\")): .totalMaxUptime.value } )\n | add\n | normalize\n | [$asset] + [.[]]\n )\n| @tsv"
    ],
    "data": [
      {
        "input": {
          "aggregations": {
            "overall": {
              "buckets": [
                {
                  "key": "2018-01-18T00:00:00.000Z-2018-01-25T19:33:16.010Z",
                  "from_as_string": "2018-01-18T00:00:00.000Z",
                  "to": 1516908796010,
                  "to_as_string": "2018-01-25T19:33:16.010Z",
                  "doc_count": 155569,
                  "agg_per_name": {
                    "doc_count_error_upper_bound": 0,
                    "sum_other_doc_count": 0,
                    "buckets": [
                      {
                        "key": "ASSET-DD583",
                        "doc_count": 3016,
                        "totalMaxUptime_perDays": {
                          "buckets": [
                            {
                              "key_as_string": "2018-01-22T00:00:00.000Z",
                              "key": 1516579200000,
                              "doc_count": 161,
                              "totalMaxUptime": {
                                "value": 77598
                              }
                            },
                            {
                              "key_as_string": "2018-01-23T00:00:00.000Z",
                              "key": 1516665600000,
                              "doc_count": 251,
                              "totalMaxUptime": {
                                "value": 80789
                              }
                            },
                            {
                              "key_as_string": "2018-01-24T00:00:00.000Z",
                              "key": 1516752000000,
                              "doc_count": 192,
                              "totalMaxUptime": {
                                "value": 56885
                              }
                            },
                            {
                              "key_as_string": "2018-01-25T00:00:00.000Z",
                              "key": 1516838400000,
                              "doc_count": 2088,
                              "totalMaxUptime": {
                                "value": 7392705
                              }
                            }
                          ]
                        }
                      },
                      {
                        "key": "ASSET-DD568",
                        "doc_count": 2990,
                        "totalMaxUptime_perDays": {
                          "buckets": [
                            {
                              "key_as_string": "2018-01-18T00:00:00.000Z",
                              "key": 1516233600000,
                              "doc_count": 106,
                              "totalMaxUptime": {
                                "value": 31241
                              }
                            },
                            {
                              "key_as_string": "2018-01-19T00:00:00.000Z",
                              "key": 1516320000000,
                              "doc_count": 241,
                              "totalMaxUptime": {
                                "value": 2952565
                              }
                            },
                            {
                              "key_as_string": "2018-01-20T00:00:00.000Z",
                              "key": 1516406400000,
                              "doc_count": 326,
                              "totalMaxUptime": {
                                "value": 2698235
                              }
                            },
                            {
                              "key_as_string": "2018-01-21T00:00:00.000Z",
                              "key": 1516492800000,
                              "doc_count": 214,
                              "totalMaxUptime": {
                                "value": 85436
                              }
                            },
                            {
                              "key_as_string": "2018-01-22T00:00:00.000Z",
                              "key": 1516579200000,
                              "doc_count": 279,
                              "totalMaxUptime": {
                                "value": 83201
                              }
                            },
                            {
                              "key_as_string": "2018-01-23T00:00:00.000Z",
                              "key": 1516665600000,
                              "doc_count": 50,
                              "totalMaxUptime": {
                                "value": 96467
                              }
                            },
                            {
                              "key_as_string": "2018-01-24T00:00:00.000Z",
                              "key": 1516752000000,
                              "doc_count": 5,
                              "totalMaxUptime": {
                                "value": 903
                              }
                            },
                            {
                              "key_as_string": "2018-01-25T00:00:00.000Z",
                              "key": 1516838400000,
                              "doc_count": 1769,
                              "totalMaxUptime": {
                                "value": 12337946
                              }
                            }
                          ]
                        }
                      },
                      {
                        "key": "ASSET-42631",
                        "doc_count": 2899,
                        "totalMaxUptime_perDays": {
                          "buckets": [
                            {
                              "key_as_string": "2018-01-18T00:00:00.000Z",
                              "key": 1516233600000,
                              "doc_count": 132,
                              "totalMaxUptime": {
                                "value": 39054
                              }
                            },
                            {
                              "key_as_string": "2018-01-19T00:00:00.000Z",
                              "key": 1516320000000,
                              "doc_count": 172,
                              "totalMaxUptime": {
                                "value": 47634
                              }
                            },
                            {
                              "key_as_string": "2018-01-20T00:00:00.000Z",
                              "key": 1516406400000,
                              "doc_count": 214,
                              "totalMaxUptime": {
                                "value": 68264
                              }
                            },
                            {
                              "key_as_string": "2018-01-21T00:00:00.000Z",
                              "key": 1516492800000,
                              "doc_count": 220,
                              "totalMaxUptime": {
                                "value": 66243
                              }
                            },
                            {
                              "key_as_string": "2018-01-25T00:00:00.000Z",
                              "key": 1516838400000,
                              "doc_count": 128,
                              "totalMaxUptime": {
                                "value": 47660
                              }
                            }
                          ]
                        }
                      }
                    ]
                  }
                }
              ]
            }
          }
        },
        "output": [
          [
            "Asset",
            "2018-01-18",
            "2018-01-19",
            "2018-01-20",
            "2018-01-21",
            "2018-01-22",
            "2018-01-23",
            "2018-01-24",
            "2018-01-25"
          ],
          [
            "ASSET-DD583",
            0,
            0,
            0,
            0,
            77598,
            80789,
            56885,
            7392705
          ],
          [
            "ASSET-DD568",
            31241,
            2952565,
            2698235,
            85436,
            83201,
            96467,
            903,
            12337946
          ],
          [
            "ASSET-42631",
            39054,
            47634,
            68264,
            66243,
            0,
            0,
            0,
            47660
          ]
        ]
      }
    ],
    "identifier": 48458395
  }
]