[
  {
    "context": [
      "basically want to get access to say accessKeyId using jq further?",
      "echo \"$cred\" | tr -d '\\n'  | jq -r '.creds.accessKeyId'"
    ],
    "utterance": "Extract the creds.accessKeyId value from the data structure.",
    "expressions": [
      ".creds.accessKeyId"
    ],
    "data": [
      {
        "input": {
          "creds": {
            "accessKeyId": "ASIAJPM3RDAZXEORAQ5Q",
            "secretAccessKey": "krg5GbU6gtQV+a5pz4ChL+ECVJm+wKogjglXOqr6",
            "sessionToken": "..."
          },
          "userUuid": "mugqRKHmTPxkobBAtwTmKk"
        },
        "output": "ASIAJPM3RDAZXEORAQ5Q"
      }
    ],
    "identifier": 50172624
  },
  {
    "context": [
      "I need to sort it by size, e.g.:",
      "You can use `to_entries` / `from_entries`, like this:",
      "jq 'to_entries|sort_by(.value.size)|from_entries' file.json"
    ],
    "utterance": "Sort the top-level object by each sub-object's size property in ascending order.",
    "expressions": [
      "to_entries | sort_by(.value.size) | from_entries"
    ],
    "data": [
      {
        "input": {
          "a": {
            "size": 3
          },
          "b": {
            "size": 2
          },
          "c": {
            "size": 1
          }
        },
        "output": {
          "c": {
            "size": 1
          },
          "b": {
            "size": 2
          },
          "a": {
            "size": 3
          }
        }
      }
    ],
    "identifier": 50119067
  },
  {
    "context": [
      "I have a JSON file `in.txt` with lines like `{\"k1\":\"v1\",\"k2\":\"v2\"}` and I want to create from it a CSV file `out.txt` with lines `v1,v2`. The JSON file may contain more than 10 key/value pairs, so I prefer a solution that doesn\u2019t require specifying each key in the input command.",
      "So far I found this command:\n\n`jq -r '[.[]] | @csv' in.txt  > out.txt`\n\nwhich produces output file with lines: `\"v1\",\"v2\"`. How can I get rid of double quotes?",
      "If you are sure that the input data does not contain a `,` you can use `join(\",\")`.",
      "`jq -r 'values|join(\",\")' input.file`",
      "Output:\n\n    v1,v2\n    v3,v4\n    v5,v6"
    ],
    "utterance": "Print each object's values as a comma-separated line, without quotes, regardless of the object's keys or value count.",
    "expressions": [
      "values | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "k1": "v1",
          "k2": "v2"
        },
        "output": "v1,v2"
      },
      {
        "input": {
          "k1": "v3",
          "k2": "v4"
        },
        "output": "v3,v4"
      }
    ],
    "identifier": 50183399
  },
  {
    "context": [
      "I want to transform JSON output into CSV file with the list of all instances, with columns 'Name,InstanceId,Tag-Client,Tag-CostCenter'.",
      "However using selects in this way, only those entries containing all the tags are displayed, not showing those that contain one of the tags only.",
      "I'm trying to figure out if it's possible to perform this operation using jq, so in the case that one tag is not defined, would just return string \"\" and not remove the whole line.",
      "So if your goal is to create rows of `Tags[Name], InstaceId, Tags[Client], Tags[CostCenter]` for each instance, you could do this:",
      ".Reservations[].Instances[]\n  | reduce .Tags[] as $t (\n        { InstanceId }; # we want the InstanceId from the instance\n        .[$t.Key] = $t.Value # add the values to the object\n    )\n  | [ .Name, .InstanceId, .Client, .CostCenter ]\n  | @csv",
      "if `Name`, `Client`, or `CostCenter` doesn't exist in the tag array, or even `InstanceId`, then they'll just be `null` which becomes empty when converted to csv."
    ],
    "utterance": "List all EC2 instances as CSV rows with columns Name, InstanceId, Client, and CostCenter, substituting empty values for missing tags.",
    "expressions": [
      ".Reservations[].Instances[]\n  | reduce .Tags[] as $t (\n        { InstanceId }; \n        .[$t.Key] = $t.Value \n    )\n  | [ .Name, .InstanceId, .Client, .CostCenter ]\n  | @csv"
    ],
    "identifier": 50130304
  },
  {
    "context": [
      "what is the `jq` program to get objects where `x` is \"bar\" `OR` `s` ends in \"X\"?",
      "Straightforwardly (specify all of your conditions within `select` function):",
      "jq -c '.b[] | select(.x == \"bar\" or (.s | endswith(\"X\")))' file.json"
    ],
    "utterance": "Select objects from array b where x equals \"bar\" or s ends with \"X\".",
    "expressions": [
      ".b[] | select(.x == \"bar\" or (.s | endswith(\"X\")))"
    ],
    "data": [
      {
        "input": {
          "a": [],
          "b": [
            {
              "x": "bar",
              "s": "FX",
              "f": [
                "blorg",
                "blarg",
                "blurb"
              ],
              "v": true
            },
            {
              "x": "bar",
              "s": "EX",
              "f": [
                "blorg",
                "blarg",
                "bloob"
              ],
              "v": false
            },
            {
              "x": "bar",
              "s": "XT",
              "f": [
                "blorg",
                "blart",
                "bloop"
              ],
              "v": true
            },
            {
              "x": "bar",
              "s": "IJ",
              "f": [
                "blorg",
                "bleep",
                "glarp"
              ],
              "v": true
            },
            {
              "x": "foo",
              "s": "IX",
              "f": [
                "porg",
                "parg",
                "pork",
                "peep"
              ],
              "v": true
            },
            {
              "x": "baz",
              "s": "AB",
              "f": [
                "zing",
                "zang",
                "zoop"
              ],
              "v": false
            }
          ],
          "c": []
        },
        "output": [
          {
            "x": "bar",
            "s": "FX",
            "f": [
              "blorg",
              "blarg",
              "blurb"
            ],
            "v": true
          },
          {
            "x": "bar",
            "s": "EX",
            "f": [
              "blorg",
              "blarg",
              "bloob"
            ],
            "v": false
          },
          {
            "x": "bar",
            "s": "XT",
            "f": [
              "blorg",
              "blart",
              "bloop"
            ],
            "v": true
          },
          {
            "x": "bar",
            "s": "IJ",
            "f": [
              "blorg",
              "bleep",
              "glarp"
            ],
            "v": true
          },
          {
            "x": "foo",
            "s": "IX",
            "f": [
              "porg",
              "parg",
              "pork",
              "peep"
            ],
            "v": true
          }
        ]
      }
    ],
    "identifier": 50139278
  },
  {
    "context": [
      "and i want to remove some unwanted values so the file should became like blow.",
      "i test and found out `map({ s, c , o })` could do that",
      "jq 'map({s, c, o})' emoji.json > tmp_json && mv tmp_json emoji.json"
    ],
    "utterance": "Extract only the properties s, c, and o from each object in the top-level array.",
    "expressions": [
      "map({s, c, o})"
    ],
    "data": [
      {
        "input": [
          {
            "name": "COPYRIGHT SIGN",
            "unified": "00A9-FE0F",
            "non_qualified": "00A9",
            "docomo": "E731",
            "au": "E558",
            "softbank": "E24E",
            "google": "FEB29",
            "image": "00a9-fe0f.png",
            "sheet_x": 0,
            "sheet_y": 12,
            "s": "copyright",
            "short_names": [
              "copyright"
            ],
            "text": null,
            "texts": null,
            "c": "Symbols",
            "o": 128,
            "added_in": "1.1",
            "has_img_twitter": false,
            "has_img_emojione": false,
            "has_img_messenger": false
          },
          {
            "name": "REGISTERED SIGN",
            "unified": "00AE-FE0F",
            "non_qualified": "00AE",
            "docomo": "E736",
            "au": "E559",
            "softbank": "E24F",
            "google": "FEB2D",
            "image": "00ae-fe0f.png",
            "sheet_x": 0,
            "sheet_y": 13,
            "s": "registered",
            "short_names": [
              "registered"
            ],
            "text": null,
            "texts": null,
            "c": "Symbols",
            "o": 129,
            "added_in": "1.1",
            "has_img_twitter": false,
            "has_img_emojione": false,
            "has_img_messenger": false
          }
        ],
        "output": [
          {
            "s": "copyright",
            "c": "Symbols",
            "o": 128
          },
          {
            "s": "registered",
            "c": "Symbols",
            "o": 129
          }
        ]
      }
    ],
    "identifier": 50198813
  },
  {
    "context": [
      "I would like to get an array with all those values that do not match a regex but am unwilling to use negative capture groups (regex is more complicated than that) - so if my criteria would be that first letter must be capital, the output array should be [\"cat\"]",
      "Sounds like `test(_) | not` is what you're looking for. Assuming you meant to write \"first letter must NOT be a capital\", the following filter could be used:",
      "map(select(test(\"^[A-Z]\")|not))"
    ],
    "utterance": "Return an array of all strings whose first letter is not a capital letter.",
    "expressions": [
      "map(select(test(\"^[A-Z]\")|not))"
    ],
    "data": [
      {
        "input": [
          "Dog",
          "cat",
          "Bird"
        ],
        "output": [
          "cat"
        ]
      }
    ],
    "identifier": 50255694
  },
  {
    "context": [
      "This is the json source:",
      "This is the json requred:",
      "How can I parse it via jq?",
      "Assuming the JSON input has been corrected, the following jq filter seems to meet the requirements, such as they are:",
      ".categories[].categories[].categories[]",
      "This produces a stream of JSON objects, beginning:",
      "{\n  \"id\": \"1.1.1\",\n  \"name\": \"Commercial Trucks\"\n}\n{\n  \"id\": \"1.1.2\",\n  \"name\": \"Convertible\"\n}"
    ],
    "utterance": "Extract each object with an id and name from the innermost categories array nested three levels deep under categories.",
    "expressions": [
      ".categories[].categories[].categories[]"
    ],
    "data": [
      {
        "input": {
          "iabVersion": "IAB_V2",
          "categories": [
            {
              "categories": [
                {
                  "categories": [
                    {
                      "id": "1.1.1",
                      "name": "Commercial Trucks"
                    },
                    {
                      "id": "1.1.2",
                      "name": "Convertible"
                    }
                  ],
                  "id": "1.1",
                  "name": "Auto Body Styles"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "id": "1.1.1",
            "name": "Commercial Trucks"
          },
          {
            "id": "1.1.2",
            "name": "Convertible"
          }
        ]
      }
    ],
    "identifier": 50252063
  },
  {
    "context": [
      "Say I want to select all objects where the `Name` ends in \"ets\" and then display the `Name` and all attributes of the form `Sym*`.  All I know about those attributes is that there will be one or more per JSON object, and the names have the format `Sym` followed by a two-letter ISO country code.",
      "I would like to just do this:\n\n    jq '.[] | select(.Name | endswith(\"ets\")) | {Name, Sym*}'\n\nbut that's not a thing.",
      "With your example data, the following filter produces the output shown below, in accordance with what I understand to be the expectations:\n\n    .[]\n    | select(.Name | test(\"ets$\"))\n    | {Name} + (to_entries | map(select(.key|test(\"^Sym\"))) | from_entries)"
    ],
    "utterance": "Select all objects where the Name ends with 'ets' and output each with the Name and all keys that start with 'Sym'.",
    "expressions": [
      ".[] | select(.Name | test(\"ets$\")) | {Name} + (to_entries | map(select(.key|test(\"^Sym\"))) | from_entries)"
    ],
    "data": [
      {
        "input": [
          {
            "Name": "Widgets",
            "Size": 10,
            "SymUS": "Widg",
            "SymCN": "Zyin",
            "SymJP": "Kono"
          },
          {
            "Name": "Blodgets",
            "Size": 400,
            "SymUS": "Blodg",
            "SymAU": "Blod",
            "SymJP": "Kado"
          },
          {
            "Name": "Fonzes",
            "Size": 11,
            "SymRU": "Fyet",
            "SymBR": "Foao"
          }
        ],
        "output": [
          {
            "Name": "Widgets",
            "SymUS": "Widg",
            "SymCN": "Zyin",
            "SymJP": "Kono"
          },
          {
            "Name": "Blodgets",
            "SymUS": "Blodg",
            "SymAU": "Blod",
            "SymJP": "Kado"
          }
        ]
      }
    ],
    "identifier": 50224055
  },
  {
    "context": [
      "I do not know the amount, nor the names of the result-objects",
      "So, I'd like to end up with : \n\n    TrBean_TrAct\n    WwwBean\n    CRFeatureBean_CRChannels\n    CRFeatureBean_getCRChannels\n    CRFeatureBean_getCRToMigrate\n    CrFeatureBean_getCRId",
      "The following jq filter produces the desired output when jq is invoked with the -r command-line option:\n\n    ((.result | keys_unsorted[]) // null) as $key\n    | if $key == null then .outcome\n      else [.outcome, $key] | join(\"_\")\n      end",
      "or if you want a short one-liner:\n\n    .outcome + (\"_\" + (.result | keys_unsorted[]) // null)"
    ],
    "utterance": "Output one line per top-level object, joining the outcome with each key in result using an underscore, or just output outcome if result is empty.",
    "expressions": [
      "((.result | keys_unsorted[]) // null) as $key | if $key == null then .outcome else [.outcome, $key] | join(\"_\") end",
      "((.result | keys_unsorted[]) // null) as $key | [.outcome, ($key // empty)] | join(\"_\")",
      ".outcome + (\"_\" + (.result | keys_unsorted[]) // null)"
    ],
    "data": [
      {
        "input": [
          {
            "outcome": "TrBean",
            "result": {
              "TrAct": {
                "executiontime": 16938570,
                "invocations": 133863,
                "waittime": 4981
              }
            }
          },
          {
            "outcome": "WwwBean",
            "result": {}
          },
          {
            "outcome": "CRFeatureBean",
            "result": {
              "CRChannels": {
                "executiontime": 78127,
                "invocations": 9983,
                "waittime": 213
              },
              "getCRChannels": {
                "executiontime": 98704,
                "invocations": 10113,
                "waittime": 212
              },
              "getCRToMigrate": {
                "executiontime": 32,
                "invocations": 4,
                "waittime": 0
              },
              "getCRId": {
                "executiontime": 28198633,
                "invocations": 747336,
                "waittime": 19856
              }
            }
          }
        ],
        "output": [
          "TrBean_TrAct",
          "WwwBean",
          "CRFeatureBean_CRChannels",
          "CRFeatureBean_getCRChannels",
          "CRFeatureBean_getCRToMigrate",
          "CRFeatureBean_getCRId"
        ]
      }
    ],
    "identifier": 50210120
  },
  {
    "context": [
      "you could replace all the \"$\" characters in template.jq with \".\", and then pass in a JSON object with the appropriate keys; e.g. change $uptime to .uptime, and then include a key/value pair for uptime."
    ],
    "utterance": "Produce an object with values under the samples list set to keys from an input object for uptime, curr_connections, listen_disabled_num, conn_yields, cmd_get, cmd_set, bytes_read, bytes_written, get_hits, rejected_connections, limit_maxbytes, and cmd_flush.",
    "expressions": [
      "jq -n --argjson input '{\"uptime\":123,\"curr_connections\":10,\"listen_disabled_num\":0,\"conn_yields\":1,\"cmd_get\":2,\"cmd_set\":3,\"bytes_read\":4,\"bytes_written\":5,\"get_hits\":6,\"rejected_connections\":7,\"limit_maxbytes\":8,\"cmd_flush\":9}' '{\n  \"test\": \"abc\",\n  \"p\": \"1\",\n  \"v\": \"1.0.0\",\n  \"samples\": [\n    {\n      \"uptime\": .input.uptime,\n      \"curr_connections\": .input.curr_connections,\n      \"listen_disabled_num\": .input.listen_disabled_num,\n      \"conn_yields\": .input.conn_yields,\n      \"cmd_get\": .input.cmd_get,\n      \"cmd_set\": .input.cmd_set,\n      \"bytes_read\": .input.bytes_read,\n      \"bytes_written\": .input.bytes_written,\n      \"get_hits\": .input.get_hits,\n      \"rejected_connections\": .input.rejected_connections,\n      \"limit_maxbytes\": .input.limit_maxbytes,\n      \"cmd_flush\": .input.cmd_flush\n    }\n  ]\n}'"
    ],
    "data": [
      {
        "input": {
          "uptime": 123,
          "curr_connections": 10,
          "listen_disabled_num": 0,
          "conn_yields": 1,
          "cmd_get": 2,
          "cmd_set": 3,
          "bytes_read": 4,
          "bytes_written": 5,
          "get_hits": 6,
          "rejected_connections": 7,
          "limit_maxbytes": 8,
          "cmd_flush": 9
        },
        "output": {
          "test": "abc",
          "p": "1",
          "v": "1.0.0",
          "samples": [
            {
              "uptime": 123,
              "curr_connections": 10,
              "listen_disabled_num": 0,
              "conn_yields": 1,
              "cmd_get": 2,
              "cmd_set": 3,
              "bytes_read": 4,
              "bytes_written": 5,
              "get_hits": 6,
              "rejected_connections": 7,
              "limit_maxbytes": 8,
              "cmd_flush": 9
            }
          ]
        }
      }
    ],
    "identifier": 50162525
  },
  {
    "context": [
      "objects having an `\"ARG\"` array, containing a string that starts with `\"BASE=\"` should use the string after `\"BASE=\"`, e.g. `\"/foo\"` to substitute other string values that start with \"`/foo\"` (except the `\"BASE=/foo\"` which should remain unchanged\"",
      "def sub_base($base): if (startswith(\"BASE\") | not) then sub($base; \"BASE\") else . end;",
      "map(if .[\"ARG\"] then ((.ARG[] | select(startswith(\"BASE=\")) | split(\"=\")[1]) as $base\n                | to_entries\n                | map(if (.value | type == \"string\") then .value |= sub_base($base)\n                      else .value |= map(sub_base($base)) end)\n                | from_entries)\n            else . end)",
      "def fix_base:\n  (.ARG[] | select(startswith(\"BASE=\")) | split(\"=\")[1]) as $base\n  | .DIR?|=\"BASE\"+ltrimstr($base)\n  | .OUT?|=\"BASE\"+ltrimstr($base)\n  | .ARG|=map(if startswith($base) then \"BASE\"+ltrimstr($base) else . end)\n  ;\n\nmap(if .ARG? then fix_base  else . end)",
      "map(if has(\"ARG\") \n    then (.ARG|indexof(test(\"^BASE=\"))) as $ix\n    | if $ix\n      then (.ARG[$ix]|sub(\"^BASE=\";\"\") ) as $base | munge($base)\n      else . end \n    else . end )"
    ],
    "utterance": "For each object with an ARG array containing a string that starts with 'BASE=', use the value after 'BASE=' to replace all string values in that object that start with it (except for the 'BASE=...' string itself), replacing the prefix with 'BASE'.",
    "expressions": [
      "def sub_base($base): if (startswith(\"BASE\") | not) then sub($base; \"BASE\") else . end;\nmap(if .[\"ARG\"] then ((.ARG[] | select(startswith(\"BASE=\")) | split(\"=\")[1]) as $base\n                | to_entries\n                | map(if (.value | type == \"string\") then .value |= sub_base($base)\n                      else .value |= map(sub_base($base)) end)\n                | from_entries)\n            else . end)",
      "def fix_base:\n  (.ARG[] | select(startswith(\"BASE=\")) | split(\"=\")[1]) as $base\n  | .DIR?|=\"BASE\"+ltrimstr($base)\n  | .OUT?|=\"BASE\"+ltrimstr($base)\n  | .ARG|=map(if startswith($base) then \"BASE\"+ltrimstr($base) else . end)\n  ;\n\nmap(if .ARG? then fix_base  else . end)",
      "def indexof(f):\n  label $out\n  | foreach .[] as $x (null; .+1; \n      if ($x|f) then (.-1, break $out) else empty end) // null;\ndef munge($base):\n  if type == \"string\" and (test(\"^BASE=\")|not) then gsub($base; \"BASE\")\n  elif type==\"array\" then map(munge($base))\n  elif type==\"object\" then map_values(munge($base))\n  else .\n  end;\nmap(if has(\"ARG\") \n    then (.ARG|indexof(test(\"^BASE=\"))) as $ix\n    | if $ix\n      then (.ARG[$ix]|sub(\"^BASE=\";\"\") ) as $base | munge($base)\n      else . end \n    else . end )"
    ],
    "data": [
      {
        "input": [
          {
            "DIR": "/foo/bar/a/b/c",
            "OUT": "/foo/bar/x/y/z",
            "ARG": [
              "aaa",
              "bbb",
              "/foo/bar/a",
              "BASE=/foo/bar"
            ]
          },
          {
            "DIR": "/foo/baz/d/e/f",
            "OUT": "/foo/baz/x/y/z",
            "ARG": [
              "ccc",
              "ddd",
              "/foo/baz/b",
              "BASE=/foo/baz"
            ]
          },
          {
            "foo": "bar"
          }
        ],
        "output": [
          {
            "DIR": "BASE/a/b/c",
            "OUT": "BASE/x/y/z",
            "ARG": [
              "aaa",
              "bbb",
              "BASE/a",
              "BASE=/foo/bar"
            ]
          },
          {
            "DIR": "BASE/d/e/f",
            "OUT": "BASE/x/y/z",
            "ARG": [
              "ccc",
              "ddd",
              "BASE/b",
              "BASE=/foo/baz"
            ]
          },
          {
            "foo": "bar"
          }
        ]
      }
    ],
    "identifier": 50131945
  },
  {
    "context": [
      "The goal is to replace the \"name\" key from demolabconfig.json with the names stored in the text file.",
      "\"name\": \"Node1\" must be replaced as \"name\":\"Tom-cat\" ... \"name\": \"Node2\" must be replaced as \"name\":\"Lucky-worm\" ... \"name\": \"Node3\" must be replaced as \"name\":\"Wom-bat\"",
      "reduce range(0; $newhostnames | length) as $i (.; .nodes[$i].name = $newhostnames[$i])",
      "jq -c --slurpfile newhostnames <(jq -nR inputs newhostnames.txt ) -f program.jq input.json",
      "If there\u2019s a chance that newhostnames.txt contains unwanted blank lines, then one way to skip them would be to add one line to program.jq so that it would look like this: ($newhostnames | map(select(length>0))) as $newhostnames | reduce range(0; $newhostnames | length) as $i (.; .nodes[$i].name = $newhostnames[$i])"
    ],
    "utterance": "Replace each object's name field under .lab.racks[].nodes[] with the corresponding value from a list of new names provided in a separate file, preserving the order.",
    "expressions": [
      "reduce range(0; $newhostnames | length) as $i (.; .lab.racks[].nodes[$i].name = $newhostnames[$i])",
      "($newhostnames | map(select(length>0))) as $newhostnames | reduce range(0; $newhostnames | length) as $i (.; .lab.racks[].nodes[$i].name = $newhostnames[$i])"
    ],
    "data": [
      {
        "input": {
          "lab": {
            "racks": [
              {
                "nodes": [
                  {
                    "name": "Node1"
                  },
                  {
                    "name": "Node2"
                  },
                  {
                    "name": "Node3"
                  }
                ]
              }
            ]
          }
        },
        "output": {
          "lab": {
            "racks": [
              {
                "nodes": [
                  {
                    "name": "Tom-cat"
                  },
                  {
                    "name": "Lucky-worm"
                  },
                  {
                    "name": "Wom-bat"
                  }
                ]
              }
            ]
          }
        }
      }
    ],
    "identifier": 50253817
  },
  {
    "context": [
      "if I select `Atlas` I want to display the `Id`",
      "jq '.[] | select(.name==\"atlas\") | .id'"
    ],
    "utterance": "Select the element whose name is \"atlas\" and return its id.",
    "expressions": [
      ".[] | select(.name==\"atlas\") | .id"
    ],
    "data": [
      {
        "input": [
          {
            "name": "atlas",
            "id": 2314430,
            "slug": "atlas",
            "description": "",
            "privacy": "closed",
            "url": "https://api.github.com/teams/2314430",
            "members_url": "https://api.github.com/teams/2314430/members{/member}",
            "repositories_url": "https://api.github.com/teams/2314430/repos",
            "permission": "pull"
          },
          {
            "name": "HAL",
            "id": 2318635,
            "slug": "hal",
            "description": "",
            "privacy": "closed",
            "url": "https://api.github.com/teams/2318635",
            "members_url": "https://api.github.com/teams/2318635/members{/member}",
            "repositories_url": "https://api.github.com/teams/2318635/repos",
            "permission": "pull"
          }
        ],
        "output": 2314430
      }
    ],
    "identifier": 50257462
  },
  {
    "context": [
      "But I want to include its key as well as: \r\n\r\n    {\r\n      \"us_rate\": {\r\n        \"amount\": \"0.00\",\r\n        \"currency\": \"USD\",\r\n        \"symbol\": \"$\"\r\n      }\r\n    }",
      "cat input.json |jq '.shipping | {us_rate: .us_rate}'",
      ".shipping | {us_rate}"
    ],
    "utterance": "Extract the us_rate field from shipping, preserving us_rate as the key in the output.",
    "expressions": [
      ".shipping | {us_rate}"
    ],
    "data": [
      {
        "input": {
          "shipping": {
            "local": true,
            "us": true,
            "us_rate": {
              "amount": "0.00",
              "currency": "USD",
              "symbol": "$"
            }
          }
        },
        "output": {
          "us_rate": {
            "amount": "0.00",
            "currency": "USD",
            "symbol": "$"
          }
        }
      }
    ],
    "identifier": 50286044
  },
  {
    "context": [
      "How can I extract only the objects `id` and `name` from this JSON via jq?",
      "The output should be look like the format below. This is just an example for the required output, the real one that I need is to catch the whole values `id` and `name` like in the JSON source.",
      "cat car.json | jq -r '.. | {name:.name?, id:.id?}'"
    ],
    "utterance": "Extract all objects with both 'id' and 'name' fields from a nested structure, outputting only their 'name' and 'id' values.",
    "expressions": [
      ".. | {name:.name?, id:.id?} | select(.name != null and .id != null)"
    ],
    "data": [
      {
        "input": {
          "name": "Automotive",
          "id": "1",
          "categories": [
            {
              "name": "Auto Body Styles",
              "id": "1.1",
              "categories": [
                {
                  "name": "Commercial Trucks",
                  "id": "1.1.1"
                },
                {
                  "name": "Convertible",
                  "id": "1.1.2"
                }
              ]
            },
            {
              "name": "Auto Buying and Selling",
              "id": "1.2"
            }
          ]
        },
        "output": [
          {
            "name": "Automotive",
            "id": "1"
          },
          {
            "name": "Auto Body Styles",
            "id": "1.1"
          },
          {
            "name": "Commercial Trucks",
            "id": "1.1.1"
          },
          {
            "name": "Convertible",
            "id": "1.1.2"
          },
          {
            "name": "Auto Buying and Selling",
            "id": "1.2"
          }
        ]
      }
    ],
    "identifier": 50273045
  },
  {
    "context": [
      "I have a large JSON file that is an array of objects, which I would like to split into smaller valid json files.",
      "Is it possible to achieve this using jq or any other off-the-shelf tools?",
      "The original JSON is in the following format",
      "[ {...}, {...}, ...]",
      "Given this input I would like to produce multiple files which are valid json"
    ],
    "utterance": "Split an array of objects into multiple smaller files, each containing valid data.",
    "expressions": [
      "jq -c '.[]' input.json | split -l 1 - part_ && for file in part_*; do mv \"$file\" \"$file.json\"; done"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "name": "foo"
          },
          {
            "id": 2,
            "name": "bar"
          }
        ]
      }
    ],
    "identifier": 50353485
  },
  {
    "context": [
      "I need to get \"mxa.mailgun.org\" with jq in bash",
      "json response from curl request to api: ...",
      "You want the \"value\" value of the *first* \"receiving_dns_records\" item:",
      "jq -r '.receiving_dns_records[0].value'"
    ],
    "utterance": "Extract the value field from the first object in receiving_dns_records when it equals 'mxa.mailgun.org'.",
    "expressions": [
      ".receiving_dns_records[0].value"
    ],
    "data": [
      {
        "input": {
          "domain": {
            "created_at": "Sun, 13 May 2018 09:48:21 GMT",
            "id": "5af809e51f4b8b00011ee1aa",
            "name": "leadedign.co.uk",
            "require_tls": false,
            "skip_verification": false,
            "smtp_login": "postmaster@leddesign.co.uk",
            "smtp_password": "07d1dee-43f1869c",
            "spam_action": "disabled",
            "state": "unverified",
            "type": "custom",
            "web_prefix": "email",
            "web_scheme": "http",
            "wildcard": false
          },
          "message": "Domain DNS records have been updated",
          "receiving_dns_records": [
            {
              "cached": [
                "1 leadeesign.co.uk"
              ],
              "priority": "10",
              "record_type": "MX",
              "valid": "unknown",
              "value": "mxa.mailgun.org"
            },
            {
              "cached": [
                "1 leaesign.co.uk"
              ],
              "priority": "10",
              "record_type": "MX",
              "valid": "unknown",
              "value": "mxb.mailgun.org"
            }
          ]
        },
        "output": "mxa.mailgun.org"
      }
    ],
    "identifier": 50354598
  },
  {
    "context": [
      "Say I create secret like so:\n\n`kubectl create secret generic testsecret --from-literal=key1=val1 --from-literal=key2=val2`\n\nNow I can run `kubectl get secret testsecret -o json` to get something like:\n\n    {\n        \"apiVersion\": \"v1\",\n        \"data\": {\n            \"key1\": \"dmFsMQ==\",\n            \"key2\": \"dmFsMg==\"\n        },\n        ...\n    }\n",
      "Sufficiently recent versions of jq have a filter for decoding base64 but it can only be used if the value that was encoded is a valid JSON string.\n\nAnyway, you could start by trying:\n\n    .data | map_values(@base64d)",
      "I read this question as asking for how to decode *all secrets* in one go.  I built on the accepted answer to produce a one-liner to do this:\n\n    kubectl get secrets -o json | jq '.items[] | {name: .metadata.name,data: .data|map_values(@base64d)}'\n\nThis has the added benefit of listing the name of the secret along with the decoded values for readability.",
      "This might be because some json might not be fully formed, use an additional filter\n\n```\nkubectl get secrets -o json | jq '.items[] |  select(null != .data) | {name: .metadata.name,data: .data|map_values(@base64d)}'\n```"
    ],
    "utterance": "Print the names and decoded key-value pairs of all secrets, skipping those with null data.",
    "expressions": [
      ".data | map_values(@base64d)",
      ".items[] | {name: .metadata.name, data: .data|map_values(@base64d)}",
      ".items[] | select(null != .data) | {name: .metadata.name, data: .data|map_values(@base64d)}"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "metadata": {
                "name": "testsecret"
              },
              "data": {
                "key1": "dmFsMQ==",
                "key2": "dmFsMg=="
              }
            },
            {
              "metadata": {
                "name": "emptysecret"
              },
              "data": null
            }
          ]
        },
        "output": [
          {
            "name": "testsecret",
            "data": {
              "key1": "val1",
              "key2": "val2"
            }
          }
        ]
      }
    ],
    "identifier": 50286066
  },
  {
    "context": [
      "whatever1 does not have dep, so create one.",
      "whatever2 has dep and does not have b.jar, so add b.jar",
      "whatever3 aready has dep and b.jar is there so untouched.",
      "cat dep.json | jq '.apps[].dep |= (. + [\"b.jar\"] | unique)'",
      "def ensure_has($key; $value):\n  if has($key) and (.[$key] | index($value)) then .\n  else .[$key] += [$value]\n  end ;\n\n.apps |= map(ensure_has(\"dep\"; \"b.jar\"))"
    ],
    "utterance": "Add 'b.jar' to the dep array of each app only if it is not already present; if dep does not exist, create it with 'b.jar'.",
    "expressions": [
      ".apps[].dep |= (. + [\"b.jar\"] | unique)",
      "def ensure_has($key; $value): if has($key) and (.[$key] | index($value)) then . else .[$key] += [$value] end ; .apps |= map(ensure_has(\"dep\"; \"b.jar\"))"
    ],
    "data": [
      {
        "input": {
          "apps": [
            {
              "name": "whatever1",
              "id": "ID1"
            },
            {
              "name": "whatever2",
              "id": "ID2",
              "dep": [
                "a.jar"
              ]
            },
            {
              "name": "whatever3",
              "id": "ID3",
              "dep": [
                "a.jar",
                "b.jar"
              ]
            }
          ]
        },
        "output": {
          "apps": [
            {
              "name": "whatever1",
              "id": "ID1",
              "dep": [
                "b.jar"
              ]
            },
            {
              "name": "whatever2",
              "id": "ID2",
              "dep": [
                "a.jar",
                "b.jar"
              ]
            },
            {
              "name": "whatever3",
              "id": "ID3",
              "dep": [
                "a.jar",
                "b.jar"
              ]
            }
          ]
        }
      }
    ],
    "identifier": 50302184
  },
  {
    "context": [
      "The goal is to be able to combine JSON, using some key as a common point between the documents.",
      "foo.json has nested data only two levels deep, but needs to be combined with data nested 1 level deep.",
      "($bar | dict(.deviceId)) as $dict\n| .Schedule |= map(. + ($dict[.deviceId|tostring] ))",
      "jq -f foobar.jq --argfile bar bar.json foo.json",
      "{\n  \"Schedule\": [\n    {\n      \"deviceId\": 123,\n      \"reservationId\": 123456,\n      \"username\": \"jdoe\",\n      \"a\": {\n        \"b\": \"10.0.0.1\",\n        \"c\": \"hostname1\"\n      }\n    },\n    {\n      \"deviceId\": 456,\n      \"reservationId\": 589114,\n      \"username\": \"jsmith\",\n      \"a\": {\n        \"b\": \"10.0.0.2\",\n        \"c\": \"hostname2\"\n      }\n    }\n  ],\n  \"serverTime\": 1522863125.019958\n}"
    ],
    "utterance": "Merge two objects by matching 'deviceId', combining fields from elements in 'Schedule' with additional data from a list of objects.",
    "expressions": [
      "def dict(f): reduce .[] as $o ({}; .[$o | f | tostring] = $o );\n($bar | dict(.deviceId)) as $dict\n| .Schedule |= map(. + ($dict[.deviceId|tostring] ))"
    ],
    "data": [
      {
        "input": {
          "foo.json": {
            "Schedule": [
              {
                "deviceId": 123,
                "reservationId": 123456,
                "username": "jdoe"
              },
              {
                "deviceId": 456,
                "reservationId": 589114,
                "username": "jsmith"
              }
            ],
            "serverTime": 1522863125.019958
          },
          "bar.json": [
            {
              "a": {
                "b": "10.0.0.1",
                "c": "hostname1"
              },
              "deviceId": 123
            },
            {
              "a": {
                "b": "10.0.0.2",
                "c": "hostname2"
              },
              "deviceId": 456
            }
          ]
        },
        "output": {
          "Schedule": [
            {
              "deviceId": 123,
              "reservationId": 123456,
              "username": "jdoe",
              "a": {
                "b": "10.0.0.1",
                "c": "hostname1"
              }
            },
            {
              "deviceId": 456,
              "reservationId": 589114,
              "username": "jsmith",
              "a": {
                "b": "10.0.0.2",
                "c": "hostname2"
              }
            }
          ],
          "serverTime": 1522863125.019958
        }
      }
    ],
    "identifier": 50296326
  },
  {
    "context": [
      "Now my all UserPool Names contains `cust_` as prefix. And i want to remove that from whole list.",
      "I know i can achieve this using [jq][1].",
      "Any help will be highly appreciated."
    ],
    "utterance": "Remove the 'cust_' prefix from all UserPool Names in the list.",
    "expressions": [
      ".UserPools[].Name | sub(\"^cust_\"; \"\")"
    ],
    "identifier": 50406258
  },
  {
    "context": [
      "I want to add a field to aggregations.domains.buckets array in below json using jq and return the full json with new fields? I want to add {\"cost\":122.45} where cost is dynamically computed for each key..",
      "If the cost is a function of the input JSON, the approach you&#39;d use would be along the lines of the following filter, which merely adds {\"cost\": null}:",
      ".aggregations.domains.buckets |= map( . + {cost} )",
      "If the cost depends on `key` according to some other criterion, then it would probably be best to construct a JSON dictionary mapping the keys to the cost, and then pass that dictionary in to jq, and combine the results using the technique illustrated at:",
      "program.jq:",
      ".aggregations.domains.buckets |=\n  reduce range(0; $costs|length) as $i (.;\n      .[$i] += {cost: $costs[$i]} )",
      "If you want the cost to be numeric, you&#39;d write:",
      "{cost: $costs[$i]|tonumber } )"
    ],
    "utterance": "Add a 'cost' field to each object in aggregations.domains.buckets array, using values from another list or mapping, and return the entire JSON with updated fields.",
    "expressions": [
      ".aggregations.domains.buckets |= map(. + {cost})",
      ".aggregations.domains.buckets |= reduce range(0; $costs|length) as $i (.; .[$i] += {cost: $costs[$i]})"
    ],
    "data": [
      {
        "input": {
          "aggregations": {
            "domains": {
              "doc_count_error_upper_bound": 0,
              "sum_other_doc_count": 0,
              "buckets": [
                {
                  "key": "other",
                  "doc_count": 8679,
                  "environments": {
                    "value": 49
                  }
                },
                {
                  "key": "CREATIVESandPREVIEWS",
                  "doc_count": 1235,
                  "environments": {
                    "value": 21
                  }
                },
                {
                  "key": "Integration",
                  "doc_count": 65,
                  "environments": {
                    "value": 1
                  }
                },
                {
                  "key": "devops",
                  "doc_count": 1,
                  "environments": {
                    "value": 1
                  }
                }
              ]
            }
          }
        },
        "output": {
          "aggregations": {
            "domains": {
              "doc_count_error_upper_bound": 0,
              "sum_other_doc_count": 0,
              "buckets": [
                {
                  "key": "other",
                  "doc_count": 8679,
                  "environments": {
                    "value": 49
                  },
                  "cost": "1280.7631275949711"
                },
                {
                  "key": "CREATIVESandPREVIEWS",
                  "doc_count": 1235,
                  "environments": {
                    "value": 21
                  },
                  "cost": "2210.8813614145324"
                },
                {
                  "key": "Integration",
                  "doc_count": 65,
                  "environments": {
                    "value": 1
                  },
                  "cost": "3143.5814890583424"
                },
                {
                  "key": "devops",
                  "doc_count": 1,
                  "environments": {
                    "value": 1
                  },
                  "cost": "836.4116237582436"
                }
              ]
            }
          }
        }
      }
    ],
    "identifier": 50341575
  },
  {
    "context": [
      "I\u2019m looking for JQ query that allows me to merge 2 arrays variables (not files) and also take me to overwrite first array with newer value from second array.",
      "What I expect the result of the merged array is",
      "jq --argjson arr1 \"$firstArr\" --argjson arr2 \"$secondArr\" -n \\\n'$arr1 + $arr2 | group_by(.Key) | map(.[-1])'",
      "jq --argjson arr1 \"$firstArr\" --argjson arr2 \"$secondArr\" -n '$arr2 + $arr1 | unique_by(.Key)'"
    ],
    "utterance": "Merge two arrays of objects by key 'Key', such that objects in the first array are overwritten by objects with the same 'Key' in the second array, and include objects unique to either array.",
    "expressions": [
      "$arr1 + $arr2 | group_by(.Key) | map(.[-1])",
      "$arr2 + $arr1 | unique_by(.Key)"
    ],
    "data": [
      {
        "input": [
          [
            {
              "Key": "A B",
              "Value": "1 2"
            },
            {
              "Key": "C D",
              "Value": "3 4"
            },
            {
              "Key": "E F",
              "Value": "5 6"
            },
            {
              "Key": "G H",
              "Value": "9 10"
            }
          ],
          [
            {
              "Key": "A B",
              "Value": "1 2"
            },
            {
              "Key": "C D",
              "Value": "3 4"
            },
            {
              "Key": "G H",
              "Value": "11 12"
            },
            {
              "Key": "J K",
              "Value": "15 16"
            }
          ]
        ],
        "output": [
          {
            "Key": "A B",
            "Value": "1 2"
          },
          {
            "Key": "C D",
            "Value": "3 4"
          },
          {
            "Key": "E F",
            "Value": "5 6"
          },
          {
            "Key": "G H",
            "Value": "11 12"
          },
          {
            "Key": "J K",
            "Value": "15 16"
          }
        ]
      }
    ],
    "identifier": 50354926
  },
  {
    "context": [
      "And I'd like to copy the key (i.e. the datetime) into the object itself to end up with:\n\n    {\n      \"2018-05-15T22:00:00Z\": {\n        \"date\": \"2018-05-15T22:00:00Z\",\n        \"foo\": \"0.0\",\n        \"bar\": \"90.0\"\n      },\n      \"2018-05-15T22:30:00Z\": {\n        \"date\": \"2018-05-15T22:30:00Z\",\n        \"foo\": \"0.0\",\n        \"bar\": \"70.0\"\n      }\n    }",
      "One approach is to use `to_entries` to split your item into a key/value pair, after which each piece can be referred to directly.",
      "`with_entries(.value = ({date: .key} + .value))`",
      "This emits the object as per the Q."
    ],
    "utterance": "Add each object's key under the property 'date' inside the corresponding value object.",
    "expressions": [
      "with_entries(.value = ({date: .key} + .value))"
    ],
    "data": [
      {
        "input": {
          "2018-05-15T22:00:00Z": {
            "foo": "0.0",
            "bar": "90.0"
          },
          "2018-05-15T22:30:00Z": {
            "foo": "0.0",
            "bar": "70.0"
          }
        },
        "output": {
          "2018-05-15T22:00:00Z": {
            "date": "2018-05-15T22:00:00Z",
            "foo": "0.0",
            "bar": "90.0"
          },
          "2018-05-15T22:30:00Z": {
            "date": "2018-05-15T22:30:00Z",
            "foo": "0.0",
            "bar": "70.0"
          }
        }
      }
    ],
    "identifier": 50359980
  },
  {
    "context": [
      "I want to change the version from master to another one, so I do the following command:",
      "cat file.json | jq '.roles[0].version = \"new\"' | jq '.version = \"new\"' | jq '.archetype_version = \"new\"' > file2.json",
      "How to save the changes to `file.json` not to `file2.json` because I&#39;ll need to use the same file later?",
      "By the way, you can compress your pipeline so that there is just one invocation of jq and no invocation of `cat`:",
      "< file.json jq '.roles[0].version = \"new\" | .version = \"new\" | .archetype_version = \"new\"' | sponge file.json"
    ],
    "utterance": "Update the values of version, archetype_version, and roles[0].version from 'master' to 'new' and overwrite the file with the changes.",
    "expressions": [
      ".roles[0].version = \"new\" | .version = \"new\" | .archetype_version = \"new\""
    ],
    "data": [
      {
        "input": {
          "src": "ssh://git@bitbucket.org/myrepos/project",
          "version": "master",
          "archetype_version": "master",
          "roles": [
            {
              "src": "ssh://git@bitbucket.org/myrepos/project",
              "version": "master"
            }
          ]
        },
        "output": {
          "src": "ssh://git@bitbucket.org/myrepos/project",
          "version": "new",
          "archetype_version": "new",
          "roles": [
            {
              "src": "ssh://git@bitbucket.org/myrepos/project",
              "version": "new"
            }
          ]
        }
      }
    ],
    "identifier": 50393951
  },
  {
    "context": [
      "I am trying to put quotation marks (\" \") around the non-numeric atomic values.",
      "The expected output is with quotes around the values.",
      "Is there any way I can add quotes using python/json or any other libraries. Or can I use jq filters to add quotes."
    ],
    "utterance": "Add double quotes to all non-numeric atomic values in the data structure, preserving numbers as numbers and quoting all unquoted strings at any depth.",
    "expressions": [
      "def quote_non_numbers:\n  if type == \"object\" then\n    with_entries(.value |= quote_non_numbers)\n  elif type == \"array\" then\n    map(quote_non_numbers)\n  elif type == \"number\" then .\n  else tostring\n  end;\nquote_non_numbers"
    ],
    "data": [
      {
        "input": {
          "Attri1": 26789381,
          "Attri2": "hjewvbfasnd3672183knsa",
          "Attri9": 457950,
          "Attri10": [
            {
              "NestedAtri1": "vwebsn632871yb",
              "NestedAttri2": [
                {
                  "A1": 0,
                  "A2": "ABB1",
                  "A3": 30,
                  "A5": [
                    "000,001"
                  ]
                },
                {
                  "A1": 0,
                  "A2": "ABB1",
                  "A3": 30,
                  "A5": [
                    "000,001"
                  ]
                }
              ]
            },
            {
              "NestedAtri1": "rgdf3423",
              "NestedAttri2": [
                {
                  "A1": 0,
                  "A2": "C",
                  "A3": 50,
                  "A5": [
                    "000,001"
                  ]
                },
                {
                  "A1": 0,
                  "A2": "ABB1",
                  "A3": 30,
                  "A5": [
                    "000,001"
                  ]
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 50399738
  },
  {
    "context": [
      "I have a lot of data in a CSV that I need to convert to nested JSON to use in a D3.js tree.",
      "Here's a jq approach that supports unlimited nesting by using recursion.  Since it's unclear exactly how the `groups` value is to be computed, the following program (program.jq) uses a fixed value.",
      "split(\"\\n\") | map(split(\",\"))\n| .[1:] # skip the headers\n| map(select(length>0))\n| gather({\"groups\":[\"CS Analyst\", \"Cyber Crime\"]})\n| .[]"
    ],
    "utterance": "Convert CSV lines representing hierarchical relationships (Domain, Subject, Section, Topic) into a nested tree structure where each node has a 'name', a fixed 'groups' array, and nested 'children'.",
    "expressions": [
      "def gather($supplement):\n  group_by(.[0])\n  | map( {name: .[0][0]} \n         + $supplement +\n         {children: (if (.[0]|length) > 2\n                     then (map(.[1:]) | gather($supplement))\n\t             else map({name:.[1]} + $supplement)\n\t             end) } )\n  ;\n\nsplit(\"\\n\") | map(split(\",\"))\n| .[1:] # skip the headers\n| map(select(length>0))\n| gather({\"groups\":[\"CS Analyst\", \"Cyber Crime\"]})\n| .[]"
    ],
    "data": [
      {
        "input": "Domain,Subject,Section,Topic\nNetworking,Networking Communications,Data Transmission,Data - Overview\nNetworking,Networking Communications,Data Transmission,Email\nNetworking,Networking Communications,Data Transmission,Datagram\nNetworking,Networking Communications,Networking Models,OSI Model\nNetworking,Networking Communications,Networking Models,TCP/IP Mode",
        "output": {
          "name": "Networking",
          "groups": [
            "CS Analyst",
            "Cyber Crime"
          ],
          "children": [
            {
              "name": "Networking Communications",
              "groups": [
                "CS Analyst",
                "Cyber Crime"
              ],
              "children": [
                {
                  "name": "Data Transmission",
                  "groups": [
                    "CS Analyst",
                    "Cyber Crime"
                  ],
                  "children": [
                    {
                      "name": "Data - Overview",
                      "groups": [
                        "CS Analyst",
                        "Cyber Crime"
                      ]
                    },
                    {
                      "name": "Email",
                      "groups": [
                        "CS Analyst",
                        "Cyber Crime"
                      ]
                    },
                    {
                      "name": "Datagram",
                      "groups": [
                        "CS Analyst",
                        "Cyber Crime"
                      ]
                    }
                  ]
                },
                {
                  "name": "Networking Models",
                  "groups": [
                    "CS Analyst",
                    "Cyber Crime"
                  ],
                  "children": [
                    {
                      "name": "OSI Model",
                      "groups": [
                        "CS Analyst",
                        "Cyber Crime"
                      ]
                    },
                    {
                      "name": "TCP/IP Mode",
                      "groups": [
                        "CS Analyst",
                        "Cyber Crime"
                      ]
                    }
                  ]
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 50285224
  },
  {
    "context": [
      "if I have a Bash variable filter **F** of the form `. <key1> . <key2> ... <keyN>` and I want to slice a Bash variable JSON object **O** so that the result is just that slice of the object including all keys in **F**, how can this be done with jq?",
      "But, I want the slice to include parent key hierarchy.",
      "Can slicing an object with a key-hierarchy filter be done more simply in jq?",
      "Provided $F is a valid jq path expression (i.e., so that `jq -n \"$F\"` works):",
      "jq \"$F as \\$v | null | $F |= \\$v\" <<< \"$O\""
    ],
    "utterance": "Extract a value at a nested path, reconstructing the full parent key hierarchy along the path specified in the filter.",
    "expressions": [
      "$F as $v | null | $F |= $v"
    ],
    "data": [
      {
        "input": {
          "a": {
            "b": {
              "c": {
                "p": 1
              },
              "x": 1
            },
            "x": 2
          },
          "x": 3
        },
        "output": {
          "a": {
            "b": {
              "c": {
                "p": 1
              }
            }
          }
        }
      },
      {
        "input": {
          "a": {
            "b": {
              "c": {
                "p": 1
              },
              "x": 1
            },
            "x": 2
          },
          "x": 3
        },
        "output": {
          "a": {
            "b": {
              "c": {
                "p": 1
              },
              "x": 1
            }
          }
        }
      }
    ],
    "identifier": 50436497
  },
  {
    "context": [
      "For example, I have a JSON object which has a root attribute name containing a period.",
      "on [jqplay.org][1] the filter `.\"foo.bar\"` successfully extracts the value of the attribute",
      "on MacOS and Linux (jq v1.5) the same input and filter (i.e. jq .\"foo.bar\" file.json produces no output.",
      "If I add brackets to the filter (i.e. .[\"foo.bar\"]) I get the following:",
      "How can I replicate the behaviour from jqplay.org on MacOS/ Linux so I can access attributes with periods in their names?",
      "OK, figured this out... I needed to wrap the whole filter in single quotes:",
      "    jq '.\"foo.bar\"' file.json",
      "cat input.json | jq .\\\"foo.bar\\\"",
      "or:\n\n    cat input.json | jq '.\"foo.bar\"'"
    ],
    "utterance": "Extract the value of the root attribute whose name contains a period and equals 'foo.bar'.",
    "expressions": [
      ".\"foo.bar\""
    ],
    "data": [
      {
        "input": {
          "foo.bar": {
            "one": 1,
            "two": "2",
            "three": {
              "a": "3a",
              "b": "3b"
            }
          }
        },
        "output": {
          "one": 1,
          "two": "2",
          "three": {
            "a": "3a",
            "b": "3b"
          }
        }
      }
    ],
    "identifier": 50444732
  },
  {
    "context": [
      "For Example I&#39;m only interested in the value of objectTypeAttributeId 887 provided that objectTypeAttributeId 911&#39;s name states as active, but then would like to return the name value of another objectTypeAttributeId",
      "if any(.[]; .objectTypeAttributeId == 911 and\n                any(.objectAttributeValues[]; .status.name == \"Active\"))\nthen map(select(.objectTypeAttributeId == 887))\nelse \"whatever\"\nend"
    ],
    "utterance": "Return the values for objectTypeAttributeId 887 only if there is an attribute with objectTypeAttributeId 911 whose status name is Active.",
    "expressions": [
      "if any(.[]; .objectTypeAttributeId == 911 and any(.objectAttributeValues[]; .status.name == \"Active\")) then map(select(.objectTypeAttributeId == 887)) else \"whatever\" end"
    ],
    "data": [
      {
        "input": [
          {
            "id": 137127,
            "objectTypeAttributeId": 887,
            "objectAttributeValues": [
              {
                "value": "false"
              }
            ],
            "objectId": 9036,
            "position": 16
          },
          {
            "id": 137128,
            "objectTypeAttributeId": 888,
            "objectAttributeValues": [
              {
                "value": "false"
              }
            ],
            "objectId": 9036,
            "position": 17
          },
          {
            "id": 137296,
            "objectTypeAttributeId": 911,
            "objectAttributeValues": [
              {
                "status": {
                  "id": 1,
                  "name": "Active",
                  "category": 1
                }
              }
            ],
            "objectId": 9036,
            "position": 18
          }
        ],
        "output": [
          {
            "id": 137127,
            "objectTypeAttributeId": 887,
            "objectAttributeValues": [
              {
                "value": "false"
              }
            ],
            "objectId": 9036,
            "position": 16
          }
        ]
      }
    ],
    "identifier": 50451535
  },
  {
    "context": [
      "Are there any smart ways to pick up the latest releases from each major  node version with `jq`?",
      "What I want to get (there are three major versions: v8, v9 and v10) the latest versions:",
      "If you pipe the output of curl into `jq -r` with the following filter, you should get the major versions, irrespective of how the version numbers are ordered in the curl results:",
      "map(.name)\n| map(split(\".\") | map(tonumber? // .) )\n| group_by(.[0])\n| map(sort)\n| map( .[-1] | map(tostring) | join(\".\"))\n| .[]",
      "def majors:\n  map( split(\".\") | map(tonumber? // .))\n  | group_by(.[0])\n  | map(sort[-1])[]\n  | map(tostring)\n  | join(\".\") ;\n\nmap( .name[1:] ) | \"v\" + majors",
      "$ jq -rf major-version.jq input.json\nv8.11.2\nv9.11.1\nv10.1.0"
    ],
    "utterance": "Return the latest release for each major node version (such as v8, v9, v10) from a list of release tags.",
    "expressions": [
      "map(.name)\n| map(split(\".\") | map(tonumber? // .) )\n| group_by(.[0])\n| map(sort)\n| map( .[-1] | map(tostring) | join(\".\"))\n| .[]",
      "def majors:\n  map( split(\".\") | map(tonumber? // .))\n  | group_by(.[0])\n  | map(sort[-1])[]\n  | map(tostring)\n  | join(\".\") ;\n\nmap( .name[1:] ) | \"v\" + majors"
    ],
    "data": [
      {
        "input": [
          {
            "name": "v10.1.0"
          },
          {
            "name": "v10.0.0"
          },
          {
            "name": "v9.11.1"
          },
          {
            "name": "v9.11.0"
          },
          {
            "name": "v9.10.1"
          },
          {
            "name": "v9.10.0"
          },
          {
            "name": "v9.9.0"
          },
          {
            "name": "v9.8.0"
          },
          {
            "name": "v9.7.1"
          },
          {
            "name": "v9.7.0"
          },
          {
            "name": "v9.6.1"
          },
          {
            "name": "v9.6.0"
          },
          {
            "name": "v9.5.0"
          },
          {
            "name": "v9.4.0"
          },
          {
            "name": "v9.3.0"
          },
          {
            "name": "v9.2.1"
          },
          {
            "name": "v9.2.0"
          },
          {
            "name": "v9.1.0"
          },
          {
            "name": "v9.0.0"
          },
          {
            "name": "v8.11.2"
          },
          {
            "name": "v8.11.1"
          },
          {
            "name": "v8.11.0"
          },
          {
            "name": "v8.10.0"
          },
          {
            "name": "v8.9.4"
          },
          {
            "name": "v8.9.3"
          },
          {
            "name": "v8.9.2"
          },
          {
            "name": "v8.9.1"
          },
          {
            "name": "v8.9.0"
          },
          {
            "name": "v8.8.1"
          },
          {
            "name": "v8.8.0"
          }
        ],
        "output": [
          "v8.11.2",
          "v9.11.1",
          "v10.1.0"
        ]
      }
    ],
    "identifier": 50440891
  },
  {
    "context": [
      "How do I get entire JSON object (resulting in the loop running 3 times) instead of outputting every single line from the test.json file?",
      "Use `jq -c`, to emit each result on a separate line. *Don&#39;t* use `-r` when your intended output is JSON, not a raw string.",
      "done < <(jq -c '.[]' <\"$1\")"
    ],
    "utterance": "Output each object from an array as a compact one-line JSON object, one per line.",
    "expressions": [
      "jq -c '.[]'"
    ],
    "data": [
      {
        "input": [
          {
            "description": "Some description",
            "name": "Some name",
            "summary": "Some summary. "
          },
          {
            "description": "Some description",
            "name": "Some name",
            "summary": "Some summary. "
          },
          {
            "description": "Some description",
            "name": "Some name",
            "summary": "Some summary. "
          }
        ],
        "output": [
          "{\"description\":\"Some description\",\"name\":\"Some name\",\"summary\":\"Some summary. \"}",
          "{\"description\":\"Some description\",\"name\":\"Some name\",\"summary\":\"Some summary. \"}",
          "{\"description\":\"Some description\",\"name\":\"Some name\",\"summary\":\"Some summary. \"}"
        ]
      }
    ],
    "identifier": 50458773
  },
  {
    "context": [
      "I want to turn this JSON into an Array in Bash, so I can do a loop around it to check for stuff, I've heard JQ can parse this, but I'm unsure in BASH how I can convert it to a useable array."
    ],
    "utterance": "Extract all values from the object as a flat array for use in a Bash script.",
    "expressions": [
      ".[]"
    ],
    "data": [
      {
        "input": {
          "pool": "www",
          "process manager": "dynamic",
          "start time": 1526919087,
          "start since": 69780,
          "accepted conn": 403320,
          "listen queue": 0,
          "max listen queue": 0,
          "listen queue len": 0,
          "idle processes": 21,
          "active processes": 6,
          "total processes": 27,
          "max active processes": 200,
          "max children reached": 1,
          "slow requests": 0
        },
        "output": [
          "www",
          "dynamic",
          1526919087,
          69780,
          403320,
          0,
          0,
          0,
          21,
          6,
          27,
          200,
          1,
          0
        ]
      }
    ],
    "identifier": 50466695
  },
  {
    "context": [
      "I want the end result to only be the dates like this:\r\n\r\n    \"createdAt\": \"17 Mei 2018\",\r\n    \"createdAt\": \"22 Mei 2018\",\r\n    \"createdAt\": \"22 Mei 2018\",\r\n    etc...",
      "Using `jq` with [update operator][1] and [sub][2] filter, you can do it as below. The slashes need to escaped twice to make it work",
      "jq '(.module.data[].fields.createdAt)|=(sub(\"Dipesan pada\\\\r\\\\n \";\"\"))' input.json"
    ],
    "utterance": "Remove the prefix 'Dipesan pada\\r\\n ' from all values in the fields.createdAt property, so that only the date remains.",
    "expressions": [
      "(.module.data[].fields.createdAt) |= (sub(\"Dipesan pada\\\\r\\\\n \";\"\"))"
    ],
    "data": [
      {
        "input": {
          "module": {
            "data": {
              "orderInfo_203759231000": {
                "fields": {
                  "createdAt": "Dipesan pada\\r\\n 17 Mei 2018",
                  "tradeOrderId": 203759231000
                }
              }
            }
          }
        },
        "output": {
          "module": {
            "data": {
              "orderInfo_203759231000": {
                "fields": {
                  "createdAt": "17 Mei 2018",
                  "tradeOrderId": 203759231000
                }
              }
            }
          }
        }
      }
    ],
    "identifier": 50461834
  },
  {
    "context": [
      "many keys are array and I want to iterate them to create different json objects in a result like this:",
      "Using your second example, this could be done like so:\r\n\r\n    range(0; .multiple_value_key|length) as $i\r\n    | . + { multiple_value_key: [.multiple_value_key[$i]],\r\n            any_key_name:       [.any_key_name[$i]] }",
      "For clarity, a helper function is defined for producing the $i-th slice of an object,\r\nthat is, for all array-valued keys with array-length greater than 1,\r\nthe value is replaced by the $i-th item in the array.\r\n\r\n    def slice($i):\r\n        map_values(if (type == \"array\" and length>1)\r\n                   then [.[$i]]\r\n                   else . end);",
      ".layers\r\n| range(0;  [.[] | length] | max) as $i\r\n| slice($i)"
    ],
    "utterance": "Produce one object per index, taking the i-th value from all array-valued keys, so each output object contains all single-valued keys unchanged and, for each array key, exactly one value from the same index.",
    "expressions": [
      "range(0; .multiple_value_key|length) as $i | . + { multiple_value_key: [.multiple_value_key[$i]], any_key_name: [.any_key_name[$i]] }",
      "def slice($i): map_values(if (type == \"array\" and length>1) then [.[$i]] else . end); .layers | range(0;  [.[] | length] | max) as $i | slice($i)"
    ],
    "data": [
      {
        "input": {
          "key_single": [
            "single_value"
          ],
          "key2": [
            "single_value"
          ],
          "multiple_value_key": [
            "value1",
            "value2"
          ],
          "any_key_name": [
            "value4",
            "value5"
          ]
        },
        "output": [
          {
            "key_single": [
              "single_value"
            ],
            "key2": [
              "single_value"
            ],
            "multiple_value_key": [
              "value1"
            ],
            "any_key_name": [
              "value4"
            ]
          },
          {
            "key_single": [
              "single_value"
            ],
            "key2": [
              "single_value"
            ],
            "multiple_value_key": [
              "value2"
            ],
            "any_key_name": [
              "value5"
            ]
          }
        ]
      },
      {
        "input": {
          "key_single": [
            "single_value"
          ],
          "key2": [
            "single_value"
          ],
          "multiple_value_key": [
            "value6",
            "value7",
            "value8"
          ],
          "any_key_name": [
            "value9",
            "value10",
            "value11"
          ]
        },
        "output": [
          {
            "key_single": [
              "single_value"
            ],
            "key2": [
              "single_value"
            ],
            "multiple_value_key": [
              "value6"
            ],
            "any_key_name": [
              "value9"
            ]
          },
          {
            "key_single": [
              "single_value"
            ],
            "key2": [
              "single_value"
            ],
            "multiple_value_key": [
              "value7"
            ],
            "any_key_name": [
              "value10"
            ]
          },
          {
            "key_single": [
              "single_value"
            ],
            "key2": [
              "single_value"
            ],
            "multiple_value_key": [
              "value8"
            ],
            "any_key_name": [
              "value11"
            ]
          }
        ]
      },
      {
        "input": {
          "layers": {
            "frame_time_epoch": [
              "1525627021.656417000"
            ],
            "ip_src": [
              "10.10.10.10"
            ],
            "ip_src_host": [
              "test"
            ],
            "ip_dst": [
              "10.10.10.11"
            ],
            "ip_dst_host": [
              "dest_test"
            ],
            "diameter_Event-Timestamp": [
              "May  6, 2018 19:17:02.000000000 CEST",
              "May  6, 2018 19:17:02.000000000 CEST"
            ],
            "diameter_Origin-Host": [
              "TESTHOST",
              "TESTHOST"
            ],
            "diameter_Destination-Host": [
              "DESTHOST",
              "DESTHOST"
            ],
            "diameter_CC-Request-Type": [
              "2",
              "2"
            ],
            "diameter_CC-Request-Number": [
              "10",
              "3"
            ],
            "diameter_Rating-Group": [
              "9004",
              "9001"
            ],
            "diameter_Called-Station-Id": [
              "testing",
              "testing"
            ],
            "diameter_User-Name": [
              "testuser",
              "testuser"
            ],
            "diameter_Subscription-Id-Data": [
              "66666666666",
              "77777777777"
            ],
            "gtp_qos_version": [
              "0x00000008",
              "0x00000005"
            ],
            "gtp_qos_max_dl": [
              "8640",
              "42"
            ],
            "diameter_Session-Id": [
              "test1;sessionID1;test1",
              "test2;sessionID2;test2"
            ]
          }
        },
        "output": [
          {
            "frame_time_epoch": [
              "1525627021.656417000"
            ],
            "ip_src": [
              "10.10.10.10"
            ],
            "ip_src_host": [
              "test"
            ],
            "ip_dst": [
              "10.10.10.11"
            ],
            "ip_dst_host": [
              "dest_test"
            ],
            "diameter_Event-Timestamp": [
              "May  6, 2018 19:17:02.000000000 CEST"
            ],
            "diameter_Origin-Host": [
              "TESTHOST"
            ],
            "diameter_Destination-Host": [
              "DESTHOST"
            ],
            "diameter_CC-Request-Type": [
              "2"
            ],
            "diameter_CC-Request-Number": [
              "10"
            ],
            "diameter_Rating-Group": [
              "9004"
            ],
            "diameter_Called-Station-Id": [
              "testing"
            ],
            "diameter_User-Name": [
              "testuser"
            ],
            "diameter_Subscription-Id-Data": [
              "66666666666"
            ],
            "gtp_qos_version": [
              "0x00000008"
            ],
            "gtp_qos_max_dl": [
              "8640"
            ],
            "diameter_Session-Id": [
              "test1;sessionID1;test1"
            ]
          },
          {
            "frame_time_epoch": [
              "1525627021.656417000"
            ],
            "ip_src": [
              "10.10.10.10"
            ],
            "ip_src_host": [
              "test"
            ],
            "ip_dst": [
              "10.10.10.11"
            ],
            "ip_dst_host": [
              "dest_test"
            ],
            "diameter_Event-Timestamp": [
              "May  6, 2018 19:17:02.000000000 CEST"
            ],
            "diameter_Origin-Host": [
              "TESTHOST"
            ],
            "diameter_Destination-Host": [
              "DESTHOST"
            ],
            "diameter_CC-Request-Type": [
              "2"
            ],
            "diameter_CC-Request-Number": [
              "3"
            ],
            "diameter_Rating-Group": [
              "9001"
            ],
            "diameter_Called-Station-Id": [
              "testing"
            ],
            "diameter_User-Name": [
              "testuser"
            ],
            "diameter_Subscription-Id-Data": [
              "77777777777"
            ],
            "gtp_qos_version": [
              "0x00000005"
            ],
            "gtp_qos_max_dl": [
              "42"
            ],
            "diameter_Session-Id": [
              "test2;sessionID2;test2"
            ]
          }
        ]
      }
    ],
    "identifier": 50247078
  },
  {
    "context": [
      "How do I use `jq` to extract the keys with some of their values?",
      "Example: Extract the names and their ages:\r\n\r\n    \"john\": 40\r\n    \"mary\": 50",
      "$ jq 'to_entries[] | \"\\(.key): \\(.value.age)\"' tmp.json",
      "to_entries[] | \"\\\"\\(.key)\\\": \\(.value.age)\"",
      "Try this:\r\n\r\n    to_entries[] | {(.key): .value.age}\r\n\r\nOutput:\r\n\r\n    {\r\n      \"john\": 40\r\n    }\r\n    {\r\n      \"mary\": 50\r\n    }"
    ],
    "utterance": "Extract each top-level key and the associated age value, outputting the name and age",
    "expressions": [
      "to_entries[] | \"\\(.key): \\(.value.age)\"",
      "to_entries[] | \"\\\"\\(.key)\\\": \\(.value.age)\"",
      "to_entries[] | {(.key): .value.age}"
    ],
    "data": [
      {
        "input": {
          "john": {
            "age": 40,
            "nickname": "jo"
          },
          "mary": {
            "age": 50,
            "nickname": "mo"
          }
        },
        "output": [
          "\"john: 40\"",
          "\"mary: 50\""
        ]
      }
    ],
    "identifier": 50495762
  },
  {
    "context": [
      "I want to remove an entire JSON block by providing specific value to JQ.",
      "And I want to remove it by providing value \"agent_credentials\" to JQ.",
      "Here\u2019s one way:\r\n\r\n    with_entries( if .value|(type==\"object\" and .identifier == \"agent_credentials\")\r\n                  then empty else . end)"
    ],
    "utterance": "Remove the object whose identifier field is equal to \"agent_credentials\".",
    "expressions": [
      "with_entries( if .value|(type==\"object\" and .identifier == \"agent_credentials\") then empty else . end )"
    ],
    "data": [
      {
        "input": {
          "some_block": {
            "deployed": false,
            "identifier": "agent_credentials",
            "value": {
              "identity": "vcap",
              "password": ""
            }
          },
          "other_block": {
            "deployed": true,
            "identifier": "something_else",
            "value": {
              "identity": "foo",
              "password": "bar"
            }
          }
        },
        "output": {
          "other_block": {
            "deployed": true,
            "identifier": "something_else",
            "value": {
              "identity": "foo",
              "password": "bar"
            }
          }
        }
      }
    ],
    "identifier": 50511240
  },
  {
    "context": [
      "But how can I parse the JSON and get 2 different CSV files as output?",
      "But I would like to get this\r\n \r\ntypes.csv\r\n\r\n    1234,\"A\"\r\n    5678,\"B\"\r\n\r\ngroups.csv\r\n\r\n    1234,\"games\"\r\n    5678,\"cars\"",
      "Can this be done without having to parse the JSON twice, first time creating the types.csv and second time the groups.csv like this?\r\n\r\n    cat testJQ.log|jq --raw-output '[.id,.type]|@csv'>types.csv\r\n    cat testJQ.log|jq --raw-output '[.id,.group]|@csv'>groups.csv",
      "$ <testJQ.log jq -r '([.id,.type]|@csv),([.id,.group]|@csv|stderr|empty)' \\\r\n        1>types.csv 2>groups.csv"
    ],
    "utterance": "Output two CSV files: one with id and type columns, and one with id and group columns, from a stream of input objects, in a single pass.",
    "expressions": [
      "([.id,.type]|@csv),([.id,.group]|@csv|stderr|empty)"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1234,
            "type": "A",
            "group": "games"
          },
          {
            "id": 5678,
            "type": "B",
            "group": "cars"
          }
        ],
        "output": {
          "types.csv": [
            "1234,\"A\"",
            "5678,\"B\""
          ],
          "groups.csv": [
            "1234,\"games\"",
            "5678,\"cars\""
          ]
        }
      }
    ],
    "identifier": 50498283
  },
  {
    "context": [
      "The function uses the same ENV var twice in the same JQ command, and in the first location the integer remains as set, and in the second line JQ subtracts 13 (WTF?) from the number.",
      "DISCORD_CHANNEL=448887356515418113",
      "jq \".discord |= . + {\\\"token\\\":\\\"${DISCORD_TOKEN}\\\"} | .discord.channels.channels |= . + {\\\"${DISCORD_CHANNEL}\\\": {}} | .minecraft.dimensions.generic |= . + {\\\"discordChannel\\\": [${DISCORD_CHANNEL}]}\" ${DISCORD_SRCCONFIG} | sponge ${DISCORD_DESTCONFIG}",
      "Unfortunately you've run into one of the major limitations of the C-based implementation of jq - numerical precision.  This implementation maps JSON numbers to IEEE 754 64-bit numbers.",
      "In general, you should not use the numeric type for large numeric strings in JSON for exactly this reason."
    ],
    "utterance": "Assign the value 448887356515418113 to a field, ensuring no loss of precision or alteration.",
    "expressions": [
      ".field = \"448887356515418113\""
    ],
    "data": [
      {
        "input": {},
        "output": {
          "field": "448887356515418113"
        }
      }
    ],
    "identifier": 50517393
  },
  {
    "context": [
      "I have an object that has an array as one of its fields. I'd like to remove the elements from the object's array that match a criteria, but keep the object around.",
      "I'd like to get back the following:\n\n    {\n      \"foo\": \"bar\",\n      \"events\": [\n        {\n          \"id\": 1,\n          \"msg\": \"starting\"\n        },\n        {\n          \"id\": 2,\n          \"msg\": \"working on it\"\n        }\n      ]\n    }",
      "The expression `.events[] | select(.id == null)` returns the key to the object where the `id` value is null and `del()` deletes that key/value pair.",
      "When in doubt (sometimes `del(...)` is a bit tricky), you can always use `map(select(...))`, e.g. in the present case:\n\n    .events |= map(select(.id != null))"
    ],
    "utterance": "Remove all elements from the 'events' array where 'id' is null, preserving the original object structure.",
    "expressions": [
      "del(.events[] | select(.id == null))",
      ".events |= map(select(.id != null))",
      ".events |= map(select(.id))"
    ],
    "data": [
      {
        "input": {
          "foo": "bar",
          "events": [
            {
              "id": 1,
              "msg": "starting"
            },
            {
              "id": 2,
              "msg": "working on it"
            },
            {
              "id": null,
              "msg": "done"
            }
          ]
        },
        "output": {
          "foo": "bar",
          "events": [
            {
              "id": 1,
              "msg": "starting"
            },
            {
              "id": 2,
              "msg": "working on it"
            }
          ]
        }
      }
    ],
    "identifier": 50533182
  },
  {
    "context": [
      "How to filter by name and get the age?  \r\nE.g., given the name being `\"Richard\"`, let `jq` return `\"32\"`.",
      "$ jq --arg name Richard '.[] | select(.name==$name) | .age' input.json\n\"32\""
    ],
    "utterance": "Return the age value for the entry where the name is \"Richard\".",
    "expressions": [
      ".[] | select(.name == \"Richard\") | .age",
      "$jq --arg name Richard '.[] | select(.name==$name) | .age' input.json"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "name": "Arthur",
            "age": "21"
          },
          {
            "id": 2,
            "name": "Richard",
            "age": "32"
          }
        ],
        "output": "32"
      }
    ],
    "identifier": 50538810
  },
  {
    "context": [
      "Currently, I'm using this filter:\r\n\r\n    {user: .results[].id, mail: .results[].buyer.email, buyer: .results[].buyer.billing_info.doc_number}\r\n\r\nAnd I'm getting a \"full join\" result.",
      "What I want is to filter some fields from the full object. So in this example, I have 2 objects, so I want 2 results:\r\n\r\n    {\"user\":111,\"mail\":\"mail1@mail.com\",\"buyer\":\"123\"}\r\n    {\"user\":222,\"mail\":\"mail2@mail.com\",\"buyer\":\"456\"}",
      "You just have to \"lift\" the iterator (`.results[]`) to the front:\r\n\r\n    .results[] \r\n    | {user: .id, mail: .buyer.email, buyer: .buyer.billing_info.doc_number}\r\n\r\nWith the -c command-line option, this produces:\r\n\r\n    {\"user\":111,\"mail\":\"mail1@mail.com\",\"buyer\":\"123\"}\r\n    {\"user\":222,\"mail\":\"mail2@mail.com\",\"buyer\":\"456\"}"
    ],
    "utterance": "Extract a list of objects containing the fields 'id' as 'user', 'buyer.email' as 'mail', and 'buyer.billing_info.doc_number' as 'buyer' from each entry in the 'results' array.",
    "expressions": [
      ".results[] | {user: .id, mail: .buyer.email, buyer: .buyer.billing_info.doc_number}"
    ],
    "data": [
      {
        "input": {
          "query": "",
          "results": [
            {
              "id": 111,
              "buyer": {
                "email": "mail1@mail.com",
                "billing_info": {
                  "doc_number": "123"
                }
              }
            },
            {
              "id": 222,
              "buyer": {
                "email": "mail2@mail.com",
                "billing_info": {
                  "doc_number": "456"
                }
              }
            }
          ]
        },
        "output": [
          {
            "user": 111,
            "mail": "mail1@mail.com",
            "buyer": "123"
          },
          {
            "user": 222,
            "mail": "mail2@mail.com",
            "buyer": "456"
          }
        ]
      }
    ],
    "identifier": 50516551
  },
  {
    "context": [
      "Better yet, you can save yourself the hassle by letting jq do the work:",
      "jq '[{termdata:.}]' original.json",
      "This will produce the desired output."
    ],
    "utterance": "Wrap the input array as the value for a key named termdata in a new object, resulting in an array containing one object with the termdata key.",
    "expressions": [
      "[{termdata:.}]"
    ],
    "data": [
      {
        "input": [
          {
            "TermCode": 2164,
            "ACAD_LEVEL_BOT": "GR",
            "ACAD_LEVEL_EOT": "GR",
            "ACAD_CAREER": "GRAD",
            "UA_PRIM_MAJ_PLN": "DPMDP",
            "UA_DEGR_DT": "1900-01-01",
            "UA_PRIM_MJ_PLN_DES": "Development Practice",
            "UA_PRIM_MIN_PLN_D": "-",
            "CUM_GPA": 3.707,
            "CUR_GPA": 4,
            "TOT_CUMULATIVE": 300,
            "UNT_PASSD_PRGRSS": 10,
            "UNT_TAKEN_PRGRSS": 10,
            "UA_PRIM_MJ_PLN_OWN": "School of Anthropology",
            "ADMIT_TYPE": "GRD",
            "ADMIT_TERM": "2144",
            "UA_FA_ST_RES_DESCR": "Resident",
            "VISA_PERMIT_TYPE": "-",
            "UA_SALT_ROSTER": "-",
            "UA_SALT_STATUS": "-",
            "DEGR_CHKOUT_STAT": "-",
            "EXP_GRAD_TERM": "-",
            "UNT_TRNSFR": 0,
            "ACAD_PROG_LD": "Graduate Degree Seeking",
            "TOT_TRNSFR": 0,
            "TUITION_RES": "RES",
            "UA_CITIZEN_COUNTRY": "United States",
            "UA_CITIZEN_ST_DESC": "Citizen",
            "ACADEMIC_LOAD": "F",
            "UNT_AUDIT": 0,
            "CAMPUS": "MAIN",
            "ACADEMIC_YEAR": "2016-2017",
            "UA_DEGREE_LEVEL": "Masters",
            "ACAD_PROG": "GDEG",
            "UA_SEC_MAJ_PLN": "-",
            "ACAD_ORG": "0410",
            "EFF_START_DT": "2016-12-18 20:37:08",
            "CURRENT_IND": "N",
            "PROG_STATUS": "AC",
            "PROG_ACTION": "MATR"
          }
        ],
        "output": [
          {
            "termdata": [
              {
                "TermCode": 2164,
                "ACAD_LEVEL_BOT": "GR",
                "ACAD_LEVEL_EOT": "GR",
                "ACAD_CAREER": "GRAD",
                "UA_PRIM_MAJ_PLN": "DPMDP",
                "UA_DEGR_DT": "1900-01-01",
                "UA_PRIM_MJ_PLN_DES": "Development Practice",
                "UA_PRIM_MIN_PLN_D": "-",
                "CUM_GPA": 3.707,
                "CUR_GPA": 4,
                "TOT_CUMULATIVE": 300,
                "UNT_PASSD_PRGRSS": 10,
                "UNT_TAKEN_PRGRSS": 10,
                "UA_PRIM_MJ_PLN_OWN": "School of Anthropology",
                "ADMIT_TYPE": "GRD",
                "ADMIT_TERM": "2144",
                "UA_FA_ST_RES_DESCR": "Resident",
                "VISA_PERMIT_TYPE": "-",
                "UA_SALT_ROSTER": "-",
                "UA_SALT_STATUS": "-",
                "DEGR_CHKOUT_STAT": "-",
                "EXP_GRAD_TERM": "-",
                "UNT_TRNSFR": 0,
                "ACAD_PROG_LD": "Graduate Degree Seeking",
                "TOT_TRNSFR": 0,
                "TUITION_RES": "RES",
                "UA_CITIZEN_COUNTRY": "United States",
                "UA_CITIZEN_ST_DESC": "Citizen",
                "ACADEMIC_LOAD": "F",
                "UNT_AUDIT": 0,
                "CAMPUS": "MAIN",
                "ACADEMIC_YEAR": "2016-2017",
                "UA_DEGREE_LEVEL": "Masters",
                "ACAD_PROG": "GDEG",
                "UA_SEC_MAJ_PLN": "-",
                "ACAD_ORG": "0410",
                "EFF_START_DT": "2016-12-18 20:37:08",
                "CURRENT_IND": "N",
                "PROG_STATUS": "AC",
                "PROG_ACTION": "MATR"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 50419955
  },
  {
    "context": [
      "I would like to emit a running counter (ie, index) for a JSON array.",
      "I am able to split the string into an array using `splits()`:",
      "How do it create a running counter for each element?",
      "I would like to have:",
      "Tom    1",
      "Dick   2",
      "Mary   3",
      "You can use `to_entries`. Try this:",
      "echo '{\"Actors\": \"Tom,Dick,Mary\"}' | jq -r '[.Actors | splits(\",\")] | to_entries | map(\"\\(.value) \\(1 + .key)\") | .[]'",
      "One can produce TSV output with `@tsv`.  With the given input,",
      "jq -r '.Actors | split(\",\") | to_entries[] | [.value,.key] | @tsv'",
      "If you want 1-based indexing, replace `.key` by `1 + .key` above."
    ],
    "utterance": "Emit each actor in the string with a running, 1-based counter alongside each name.",
    "expressions": [
      "[.Actors | splits(\",\")] | to_entries | map(\"\u0005c(.value) \\(1 + .key)\") | .[]",
      ".Actors | split(\",\") | to_entries[] | [ .value, (1 + .key) ] | @tsv"
    ],
    "data": [
      {
        "input": {
          "Actors": "Tom,Dick,Mary"
        },
        "output": [
          "Tom    1",
          "Dick   2",
          "Mary   3"
        ]
      }
    ],
    "identifier": 50557803
  },
  {
    "context": [
      "Sample Input:",
      "[\"https://test-ci.cmxdev.com/dev/AD-885/?oauth=callback\",  ",
      "\"https://test-ci.cmxdev.com/dev/INS-1676-a/?oauth=callback\",  ",
      "\"https://test-jdtest.cmxdev.com?oauth=callback\",  ",
      "\"https://localhost:3000?oauth=callback\"]",
      "Sample Output (Removed 2nd element):",
      "[\"https://test-ci.cmxdev.com/dev/AD-885/?oauth=callback\",   ",
      "\"https://test-jdtest.cmxdev.com?oauth=callback\",  ",
      "\"https://localhost:3000?oauth=callback\"]",
      "map(select(. != \"https://test-ci.cmxdev.com/dev/INS-1676-a/?oauth=callback\"))"
    ],
    "utterance": "Remove from an array all elements equal to \"https://test-ci.cmxdev.com/dev/INS-1676-a/?oauth=callback\".",
    "expressions": [
      "map(select(. != \"https://test-ci.cmxdev.com/dev/INS-1676-a/?oauth=callback\"))",
      ". - [\"https://test-ci.cmxdev.com/dev/INS-1676-a/?oauth=callback\"]"
    ],
    "data": [
      {
        "input": [
          "https://test-ci.cmxdev.com/dev/AD-885/?oauth=callback",
          "https://test-ci.cmxdev.com/dev/INS-1676-a/?oauth=callback",
          "https://test-jdtest.cmxdev.com?oauth=callback",
          "https://localhost:3000?oauth=callback"
        ],
        "output": [
          "https://test-ci.cmxdev.com/dev/AD-885/?oauth=callback",
          "https://test-jdtest.cmxdev.com?oauth=callback",
          "https://localhost:3000?oauth=callback"
        ]
      }
    ],
    "identifier": 50562680
  },
  {
    "context": [
      "What I want is for the array boundaries of the group array to be preserved.",
      "It seems that, in essence, you should be using `map` instead of `.[]`.",
      "map(.members | map({name: .roomName, state: .state.playbackState, vol: .state.volume}) )"
    ],
    "utterance": "Produce an array where each element is an array of simplified member objects, preserving the original groupings.",
    "expressions": [
      "map(.members | map({name: .roomName, state: .state.playbackState, vol: .state.volume}))"
    ],
    "data": [
      {
        "input": [
          {
            "id": "000E58D2E9B401400",
            "members": [
              {
                "id": "000E58D2E9B401400",
                "roomName": "Room1",
                "groupState": {
                  "mute": false,
                  "volume": 15
                },
                "state": {
                  "playbackState": "STOPPED",
                  "volume": 15,
                  "mute": false
                }
              }
            ]
          },
          {
            "id": "000E58D2FA0601400",
            "members": [
              {
                "state": {
                  "playbackState": "STOPPED",
                  "volume": 40,
                  "mute": false
                },
                "id": "000E58D2FA0601400",
                "roomName": "Room2",
                "groupState": {
                  "mute": false,
                  "volume": 40
                }
              }
            ]
          },
          {
            "id": "5CAAFD7B8C9801400",
            "members": [
              {
                "groupState": {
                  "mute": false,
                  "volume": 15
                },
                "roomName": "Room3",
                "id": "5CAAFD7B8C9801400",
                "state": {
                  "mute": false,
                  "playbackState": "STOPPED",
                  "volume": 15
                }
              }
            ]
          }
        ],
        "output": [
          [
            {
              "name": "Room1",
              "state": "STOPPED",
              "vol": 15
            }
          ],
          [
            {
              "name": "Room2",
              "state": "STOPPED",
              "vol": 40
            }
          ],
          [
            {
              "name": "Room3",
              "state": "STOPPED",
              "vol": 15
            }
          ]
        ]
      },
      {
        "input": [
          {
            "id": "000E58D2E9B401400",
            "members": [
              {
                "id": "000E58D2E9B401400",
                "state": {
                  "volume": 44,
                  "mute": false,
                  "playbackState": "PAUSED_PLAYBACK",
                  "equalizer": {
                    "bass": 2,
                    "treble": 2,
                    "loudness": true
                  }
                },
                "roomName": "Room1",
                "groupState": {
                  "volume": 46,
                  "mute": false
                }
              },
              {
                "id": "5CAAFDE9614001400",
                "state": {
                  "volume": 54,
                  "mute": false,
                  "playbackState": "PAUSED_PLAYBACK",
                  "equalizer": {
                    "bass": 0,
                    "treble": 0,
                    "loudness": true
                  }
                },
                "roomName": "Room2",
                "groupState": {
                  "volume": 65,
                  "mute": false
                }
              },
              {
                "id": "5CAAFD7B8C9801400",
                "state": {
                  "volume": 41,
                  "mute": false,
                  "playbackState": "PAUSED_PLAYBACK",
                  "equalizer": {
                    "bass": 0,
                    "treble": 0,
                    "loudness": false
                  }
                },
                "roomName": "Room3",
                "groupState": {
                  "volume": 41,
                  "mute": false
                }
              }
            ]
          }
        ],
        "output": [
          [
            {
              "name": "Room1",
              "state": "PAUSED_PLAYBACK",
              "vol": 44
            },
            {
              "name": "Room2",
              "state": "PAUSED_PLAYBACK",
              "vol": 54
            },
            {
              "name": "Room3",
              "state": "PAUSED_PLAYBACK",
              "vol": 41
            }
          ]
        ]
      }
    ],
    "identifier": 50439331
  },
  {
    "context": [
      "sudo jq -c  '.interpreterSettings.\"2ANGGHHMQ\".\"properties\".\"zeppelin.pyspark.python\" = \"python3\"' interpreter.json > tmp.$$.json && mv tmp.$$.json interpreter.json"
    ],
    "utterance": "Set the value of interpreterSettings.\"2ANGGHHMQ\".properties.\"zeppelin.pyspark.python\" to \"python3\" in the data.",
    "expressions": [
      ".interpreterSettings.\"2ANGGHHMQ\".\"properties\".\"zeppelin.pyspark.python\" = \"python3\""
    ],
    "identifier": 50594275
  },
  {
    "context": [
      "What I want to get is the object where elements of `\"a\"` will be concatenated:",
      "jq -s '.[1].a as $a1 | .[0] | (.a += $a1)'",
      "Since you don't care about the non-a keys, an alternative would be:",
      "jq -n '{a: (input.a + input.a)}'"
    ],
    "utterance": "Combine the arrays under the key 'a' from two objects into a single array containing all their elements.",
    "expressions": [
      "jq -s '.[1].a as $a1 | .[0] | (.a += $a1)'",
      "jq -n '{a: (input.a + input.a)}'"
    ],
    "data": [
      {
        "input": [
          {
            "a": [
              "1-1",
              "1-2"
            ],
            "other": "foo"
          },
          {
            "a": [
              "2-1",
              "2-2",
              "2-3"
            ],
            "other": "bar"
          }
        ],
        "output": {
          "a": [
            "1-1",
            "1-2",
            "2-1",
            "2-2",
            "2-3"
          ],
          "other": "foo"
        }
      }
    ],
    "identifier": 50569174
  },
  {
    "context": [
      "But now I need to move all `b`s (that need not exist!) one level down like this:",
      "walk( if type == \"object\" and has(\"b\")\n      then .e = .b | del(.b)\n      else . end )"
    ],
    "utterance": "Move every field named 'b' into a new field 'e' as its child, wherever 'b' exists, at any depth.",
    "expressions": [
      "walk( if type == \"object\" and has(\"b\") then .e = .b | del(.b) else . end )"
    ],
    "data": [
      {
        "input": {
          "x": [
            {
              "a": {
                "b": [],
                "c": 42
              }
            },
            {
              "a": {
                "d": true
              }
            }
          ]
        },
        "output": {
          "x": [
            {
              "a": {
                "e": {
                  "b": []
                },
                "c": 42
              }
            },
            {
              "a": {
                "d": true
              }
            }
          ]
        }
      }
    ],
    "identifier": 50604423
  },
  {
    "context": [
      "I want to produce json file with structure like this:\n\n    {\n      \"data\": [\n        [\n          \"Tiger Nixon\",\n          \"Edinburgh\"\n        ],\n        [\n          \"Garrett Winters\",\n          \"Tokyo\"\n        ]\n      ]\n    }\n",
      "for url in \"${list[@]}\"; do\n  echo \"${hypothetical_data[$url]}\"  # or curl \"$url\"\ndone | jq -n '{\"data\": [inputs | [.foo, .bar]]}'"
    ],
    "utterance": "Combine objects with properties foo and bar into an array of arrays containing their values mapped to data.",
    "expressions": [
      "{\"data\": [inputs | [.foo, .bar]]}"
    ],
    "data": [
      {
        "input": [
          {
            "foo": "Tiger Nixon",
            "bar": "Edinburgh"
          },
          {
            "foo": "Garrett Winters",
            "bar": "Tokyo"
          }
        ],
        "output": {
          "data": [
            [
              "Tiger Nixon",
              "Edinburgh"
            ],
            [
              "Garrett Winters",
              "Tokyo"
            ]
          ]
        }
      }
    ],
    "identifier": 50572809
  },
  {
    "context": [
      "I am trying to update branches.json.branch2 values from branch2.json.Employes values",
      "How can I merge content of one file to another file",
      "$ jq 'reduce inputs as $i (. ; .[input_filename|rtrimstr(\".json\")] = $i.Employes )' branches.json branch{1,2}.json"
    ],
    "utterance": "Update the value of the 'branch2' key in branches.json to the Employes array from branch2.json, matching the key to the file name.",
    "expressions": [
      "jq 'reduce inputs as $i (.; .[input_filename|rtrimstr(\".json\")] = $i.Employes)' branches.json branch2.json"
    ],
    "data": [
      {
        "input": {
          "branches.json": {
            "branch1": [
              {
                "Name": "Ikon",
                "age": "30"
              },
              {
                "Name": "Lenon",
                "age": "35"
              }
            ],
            "branch2": [
              {
                "Name": "Old",
                "age": "99"
              }
            ]
          },
          "branch2.json": {
            "Employes": [
              {
                "Name": "Ken",
                "age": "40"
              },
              {
                "Name": "Frank",
                "age": "23"
              }
            ]
          }
        },
        "output": {
          "branch1": [
            {
              "Name": "Ikon",
              "age": "30"
            },
            {
              "Name": "Lenon",
              "age": "35"
            }
          ],
          "branch2": [
            {
              "Name": "Ken",
              "age": "40"
            },
            {
              "Name": "Frank",
              "age": "23"
            }
          ]
        }
      }
    ],
    "identifier": 50560499
  },
  {
    "context": [
      "I have a file output called file.json. I need to convert this file to a .csv file for better viewing since this is the output of AQL.",
      "There are multiple such fields with same parameters which I need to convert to a CSV format i.e in a .csv file."
    ],
    "utterance": "Extract all fields from each object in the 'results' array, including nested 'properties' and 'stats', and convert the data into CSV format for easier viewing.",
    "expressions": [
      ".results[] | {file, path, type, created} + ( .properties | map({(.tracker): .value}) | add ) + ( .stats[0] // {} ) | [ .file, .path, .type, .created, .\"file.name\", .\"file.number\", .downloaded, .downloads ] | @csv"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "file": "abc-trip-typ",
              "path": "pit/pop/tracker",
              "type": "file",
              "created": "2018\u201305-05:09:00",
              "properties": [
                {
                  "tracker": "file.name",
                  "value": "PRN_TY.0.0"
                },
                {
                  "tracker": "file.number",
                  "value": "9"
                }
              ],
              "stats": [
                {
                  "downloaded": "2018-05-05:10:00",
                  "downloads": 10
                }
              ]
            }
          ]
        },
        "output": "\"abc-trip-typ\",\"pit/pop/tracker\",\"file\",\"2018\u201305-05:09:00\",\"PRN_TY.0.0\",\"9\",\"2018-05-05:10:00\",10"
      }
    ],
    "identifier": 50621507
  },
  {
    "context": [
      "I would like to extract `age` from the above json using `jq`",
      "The pedestrian way:\r\n\r\n    .[] | .[] | .age",
      "The briefer way:\r\n\r\n    .[][].age",
      "Another possibility to consider (it has different semantics) would be:\r\n\r\n     .. | .age?"
    ],
    "utterance": "Extract the value of the age field from objects nested within double arrays.",
    "expressions": [
      ".[] | .[] | .age",
      ".[][].age",
      ".. | .age?"
    ],
    "data": [
      {
        "input": [
          [
            {
              "name": "x",
              "age": "y",
              "class": "z"
            }
          ]
        ],
        "output": [
          "y"
        ]
      }
    ],
    "identifier": 50649235
  },
  {
    "context": [
      "Error response: `{ \"error\": \"error_message\" }` - single struct.",
      "Good response: `[ { \"element1\": \"value1\", \"element2\": \"value2\", \"element3\": \"value3\" } ]` - array of structs of 3 elements (fixed amount).",
      "I was trying to check if it's an error  with `echo ${json} | jq '. | select (.| has(\"error\")) | has(\"error\")'`, but this works only if it's an error response, if it's a \"good\" one - jq fails.",
      "If you know that the responses are going to be of a specific type (an object vs an array), you could just test for that type.",
      "You should consider calling jq just once, along the lines: if type == \"object\" then ... else ... end"
    ],
    "utterance": "Determine whether the response is an object (indicating an error) or an array (indicating a good response) to distinguish between error and success cases.",
    "expressions": [
      "if type == \"object\" then true else false end",
      ". | type == \"object\""
    ],
    "data": [
      {
        "input": {
          "error": "error_message"
        },
        "output": true
      },
      {
        "input": [
          {
            "element1": "value1",
            "element2": "value2",
            "element3": "value3"
          }
        ],
        "output": false
      }
    ],
    "identifier": 50647869
  },
  {
    "context": [
      "and I want to show the object that only has `\"cartItemId\": 2081021134` so the end result should look like this:",
      "jq 'select(.cartItemId==2081021134)' input.json",
      "You have to go digging a little deeper. Feed the values of the object to `select`, and check `.fields.cartItemId`, not just `.cartItemId`.",
      "jq '.[] | select(.fields.cartItemId == 2081021134)' input.json",
      "This produces the desired output.  Using `with_entries` makes it easy to retain the keys.",
      "with_entries( if .value | has(\"fields\") \n                  then select(.value.fields.cartItemId == 2081021134)\n                  else . end)"
    ],
    "utterance": "Return the object entry whose fields.cartItemId equals 2081021134, preserving the key.",
    "expressions": [
      ".[] | select(.fields.cartItemId == 2081021134)",
      "with_entries( if .value | has(\"fields\") then select(.value.fields.cartItemId == 2081021134) else . end )"
    ],
    "data": [
      {
        "input": {
          "item_i7bfe8f00": {
            "id": "i7bfe8f00",
            "tag": "item",
            "fields": {
              "img": "https://example.com",
              "quantity": {
                "qtyPrefix": "Kuantitas",
                "min": 1,
                "autoOptions": false,
                "quantity": 5,
                "max": 5,
                "editable": true,
                "showIncrDecr": true,
                "showOptions": false,
                "step": 1
              },
              "sellerName": "ALL ITEM STORE",
              "title": "Xiaomi Redmi 4A Softcase Black",
              "stockTip": {},
              "valid": true,
              "itemId": "143800088",
              "operations": [
                "wishlist",
                "delete"
              ],
              "sellerId": "100124080",
              "price": {
                "price": 3500,
                "currentPrice": "Rp3.500",
                "originPrice": "Rp15.000",
                "promotionRatio": "-77%"
              },
              "restriction": false,
              "isGift": false,
              "sku": {
                "skuText": "Softcase, Hitam",
                "productVariant": "SO908ELAAVYY4AANID-72544754",
                "brandId": "17818",
                "skuId": "157608391"
              },
              "itemUrl": "https://example.com",
              "cartItemId": 2080280320
            },
            "type": "biz"
          },
          "item_i7c09dcce": {
            "id": "i7c09dcce",
            "tag": "item",
            "fields": {
              "img": "https://example.com",
              "quantity": {
                "qtyPrefix": "Kuantitas",
                "min": 1,
                "autoOptions": false,
                "quantity": 1,
                "max": 5,
                "editable": true,
                "showIncrDecr": true,
                "showOptions": false,
                "step": 1
              },
              "sellerName": "PT. Ecart Services Indonesia",
              "title": "Black",
              "stockTip": {},
              "valid": true,
              "itemId": "345695828",
              "operations": [
                "wishlist",
                "delete"
              ],
              "sellerId": "100161156",
              "price": {
                "price": 2499000,
                "currentPrice": "Rp2.499.000"
              },
              "restriction": false,
              "isGift": false,
              "sku": {
                "skuText": "Hitam",
                "productVariant": "345695828_ID-359330058",
                "brandId": "21734",
                "skuId": "359330058"
              },
              "itemUrl": "https://example.com",
              "cartItemId": 2081021134
            },
            "type": "biz"
          }
        },
        "output": {
          "item_i7c09dcce": {
            "id": "i7c09dcce",
            "tag": "item",
            "fields": {
              "img": "https://example.com",
              "quantity": {
                "qtyPrefix": "Kuantitas",
                "min": 1,
                "autoOptions": false,
                "quantity": 1,
                "max": 5,
                "editable": true,
                "showIncrDecr": true,
                "showOptions": false,
                "step": 1
              },
              "sellerName": "PT. Ecart Services Indonesia",
              "title": "Black",
              "stockTip": {},
              "valid": true,
              "itemId": "345695828",
              "operations": [
                "wishlist",
                "delete"
              ],
              "sellerId": "100161156",
              "price": {
                "price": 2499000,
                "currentPrice": "Rp2.499.000"
              },
              "restriction": false,
              "isGift": false,
              "sku": {
                "skuText": "Hitam",
                "productVariant": "345695828_ID-359330058",
                "brandId": "21734",
                "skuId": "359330058"
              },
              "itemUrl": "https://example.com",
              "cartItemId": 2081021134
            },
            "type": "biz"
          }
        }
      }
    ],
    "identifier": 50475054
  },
  {
    "context": [
      "what I would like jq to output (in order to extract and set variables using eval) :",
      "data1=\"some data\"",
      "data2=\"some data\"",
      "key1_data3=\"some data\"",
      "key1_data4=\"some data\"",
      "key2_data5=\"some data\"",
      "You can use the `paths` function to get paths to each of the scalar values, then `getpath` to retrieve the value that path leads to. `$p` records the paths for later use.",
      "$ jq -r 'paths(scalars) as $p | \"\\($p|join(\"_\"))=\\\"\\(getpath($p))\\\"\"' tmp.json",
      "data1=\"some data\"",
      "data2=\"some data\"",
      "key1_data3=\"some data\"",
      "key1_data4=\"some data\"",
      "key2_data5=\"some data\""
    ],
    "utterance": "Output all scalar values with their full key path, joined by underscores, in the form KEY=VALUE with quotes.",
    "expressions": [
      "paths(scalars) as $p | \"\\($p|join(\"_\"))=\\\"\\(getpath($p))\\\"\""
    ],
    "data": [
      {
        "input": {
          "data1": "some data",
          "data2": "some data",
          "key1": {
            "data3": "some data",
            "data4": "some data"
          },
          "key2": {
            "data5": "some data"
          }
        },
        "output": [
          "data1=\"some data\"",
          "data2=\"some data\"",
          "key1_data3=\"some data\"",
          "key1_data4=\"some data\"",
          "key2_data5=\"some data\""
        ]
      }
    ],
    "identifier": 50553799
  },
  {
    "context": [
      "You need to do two things: one, use the `-s` option so that each separate object becomes an element of a single array. Two, you are trying to index the `Name`, instead of accessing the `Name` attribute of an array element.",
      "$ jq -sr '[].Name' tmp.json",
      "If you wanted to refer to a specific element of the stream, you could:",
      "$ jq -sr '.[1].Name' tmp.json",
      "To select only the first name, you need to do the indexing **before** trying to go into the `Name` element:",
      "jq -rs '[0].Name'"
    ],
    "utterance": "Select the 'Name' value of the first object in a sequence of objects provided as separate JSON documents.",
    "expressions": [
      "jq -sr '.[0].Name' tmp.json",
      "jq -rs '.[0].Name' tmp.json"
    ],
    "data": [
      {
        "input": [
          {
            "Name": "testuser1",
            "Username": "testuser1",
            "Url": "www.test1.com"
          },
          {
            "Name": "testuser2",
            "Username": "testuser2",
            "Url": "www.test2.com"
          }
        ],
        "output": "testuser1"
      }
    ],
    "identifier": 50649937
  },
  {
    "context": [
      "I need only the value of id (in my case the f34fdasdfaa4364adc42b3a57)",
      "id=$(jq -r '.result.id' id.txt)",
      "Output to variable `id`:\nf34fdasdfaa4364adc42b3a57"
    ],
    "utterance": "Extract the value of the nested key 'id' under 'result'",
    "expressions": [
      ".result.id",
      "-r .result.id"
    ],
    "data": [
      {
        "input": {
          "result": {
            "id": "f34fdasdfaa4364adc42b3a57",
            "modified_on": "2018-06-02T17:08:17.106435Z"
          },
          "success": true
        },
        "output": "f34fdasdfaa4364adc42b3a57"
      }
    ],
    "identifier": 50659384
  },
  {
    "context": [
      "Given an **arbitrary** JSON input:",
      "And an **arbitrary** list of JQ paths like `[\".turtles[].name\", \".cast\", \".does.not.exist\"]`, or any similar format",
      "How can I create new JSON with only the information contained in the paths of the list?",
      "In this case the expected result would be:",
      "{  \n   \"turtles\":[  \n      {  \n         \"name\":\"Leonardo\"\n      },\n      {  \n         \"name\":\"Michelangelo\"\n      },\n      {  \n         \"name\":\"Donatello\"\n      },\n      {  \n         \"name\":\"Raphael\"\n      }\n   ],\n   \"cast\":\"Megan Fox, Will Arnett, Tyler Perry\"\n}",
      "If $paths contains an array of explicit jq paths (such as `[ [\"turtles\", 0, \"name\"], [\"cast\"] ])`, the simplest approach would be to\nuse the following filter:",
      ". as $in\n| reduce $paths[] as $p (null; setpath($p; $in | getpath($p)))",
      "For the sake of exposition, let us also define:\n\ndef paths($ary): $ary[] as $path | xpath($path);",
      "Then with the given input, the expression:\n\n    . as $in\n    | reduce paths([ [\"turtles\", [], \"name\"], [\"cast\"]]) as $p \n        (null; setpath($p; $in | getpath($p)) )",
      "For example:\n\ndef paths: path(.turtles[].name), [\"cast\"];\n\n.as $in\n| reduce paths as $p (null; setpath($p; $in | getpath($p)))"
    ],
    "utterance": "Extract only the fields matching paths like .turtles[].name and .cast into a new object containing just those parts.",
    "expressions": [
      ". as $in | reduce $paths[] as $p (null; setpath($p; $in | getpath($p)))",
      "def xpath($ary):\n  . as $in\n  | if ($ary|length) == 0 then null\n    else $ary[0] as $k\n    | if $k == []\n      then range(0;length) as $i | $in[$i] | xpath($ary[1:]) | [$i] + .\n      else .[$k] | xpath($ary[1:]) | [$k] + . \n      end\n    end;\ndef paths($ary): $ary[] as $path | xpath($path);\n.as $in | reduce paths([ [\"turtles\", [], \"name\"], [\"cast\"] ]) as $p (null; setpath($p; $in | getpath($p)))",
      "def paths: path(.turtles[].name), [\"cast\"]; . as $in | reduce paths as $p (null; setpath($p; $in | getpath($p)))"
    ],
    "data": [
      {
        "input": {
          "id": "038020",
          "title": "Teenage Mutant Ninja Turtles: Out of the Shadows",
          "turtles": [
            {
              "name": "Leonardo",
              "mask": "blue"
            },
            {
              "name": "Michelangelo",
              "mask": "orange"
            },
            {
              "name": "Donatello",
              "mask": "purple"
            },
            {
              "name": "Raphael",
              "mask": "red"
            }
          ],
          "summary": "The Turtles continue to live in the shadows and no one knows they were the ones who took down Shredder",
          "cast": "Megan Fox, Will Arnett, Tyler Perry",
          "director": "Dave Green"
        },
        "output": {
          "turtles": [
            {
              "name": "Leonardo"
            },
            {
              "name": "Michelangelo"
            },
            {
              "name": "Donatello"
            },
            {
              "name": "Raphael"
            }
          ],
          "cast": "Megan Fox, Will Arnett, Tyler Perry"
        }
      }
    ],
    "identifier": 50615080
  },
  {
    "context": [
      "I\u2019m interested in the `genes_id` and `pathways` for both objects and want to obtain a tab separated file containing the following:",
      "However I want to *spread* the pathways out to individual rows as in the above example.",
      "Program (totsv.jq):",
      ".[]\n| .genes_id as $id\n| .pathways\n| to_entries[]\n| [$id, .key, .value]\n| @tsv"
    ],
    "utterance": "For each object, output the genes_id, each pathway id, and the corresponding pathway description as separate tab-separated rows.",
    "expressions": [
      ".[]\n| .genes_id as $id\n| .pathways\n| to_entries[]\n| [$id, .key, .value]\n| @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "genes_id": "eco:b0002",
            "entry_id": "b0002",
            "division": "CDS",
            "organism": "Escherichia coli K-12 MG1655",
            "organism_code": "eco",
            "organism_id": "T00007",
            "name": "thrA",
            "names": [
              "thrA"
            ],
            "definition": "(RefSeq) Bifunctional aspartokinase/homoserine dehydrogenase 1",
            "eclinks": [],
            "orthologs": {
              "K12524": "bifunctional aspartokinase / homoserine dehydrogenase 1 [EC:2.7.2.4 1.1.1.3]"
            },
            "pathways": {
              "eco00260": "Glycine, serine and threonine metabolism",
              "eco00261": "Monobactam biosynthesis",
              "eco00270": "Cysteine and methionine metabolism",
              "eco00300": "Lysine biosynthesis",
              "eco01100": "Metabolic pathways",
              "eco01110": "Biosynthesis of secondary metabolites",
              "eco01120": "Microbial metabolism in diverse environments",
              "eco01130": "Biosynthesis of antibiotics",
              "eco01230": "Biosynthesis of amino acids"
            },
            "modules": {
              "eco_M00016": "Lysine biosynthesis, succinyl-DAP pathway, aspartate => lysine",
              "eco_M00017": "Methionine biosynthesis, apartate => homoserine => methionine",
              "eco_M00018": "Threonine biosynthesis, aspartate => homoserine => threonine"
            },
            "classes": [],
            "position": "337..2799",
            "chromosome": null,
            "gbposition": "337..2799",
            "motifs": {
              "Pfam": [
                "Homoserine_dh",
                "AA_kinase",
                "NAD_binding_3",
                "ACT_7",
                "ACT",
                "Sacchrp_dh_NADP"
              ]
            },
            "dblinks": {
              "NCBI-GeneID": [
                "945803"
              ],
              "NCBI-ProteinID": [
                "NP_414543"
              ],
              "Pasteur": [
                "thrA"
              ],
              "RegulonDB": [
                "ECK120000987"
              ],
              "ECOCYC": [
                "EG10998"
              ],
              "ASAP": [
                "ABE-0000008"
              ],
              "UniProt": [
                "P00561"
              ]
            }
          },
          {
            "genes_id": "eco:b0003",
            "entry_id": "b0003",
            "division": "CDS",
            "organism": "Escherichia coli K-12 MG1655",
            "organism_code": "eco",
            "organism_id": "T00007",
            "name": "thrB",
            "names": [
              "thrB"
            ],
            "definition": "(RefSeq) homoserine kinase",
            "eclinks": [],
            "orthologs": {
              "K00872": "homoserine kinase [EC:2.7.1.39]"
            },
            "pathways": {
              "eco00260": "Glycine, serine and threonine metabolism",
              "eco01100": "Metabolic pathways",
              "eco01110": "Biosynthesis of secondary metabolites",
              "eco01120": "Microbial metabolism in diverse environments",
              "eco01230": "Biosynthesis of amino acids"
            },
            "modules": {
              "eco_M00018": "Threonine biosynthesis, aspartate => homoserine => threonine"
            },
            "classes": [],
            "position": "2801..3733",
            "chromosome": null,
            "gbposition": "2801..3733",
            "motifs": {
              "Pfam": [
                "GHMP_kinases_N",
                "GHMP_kinases_C"
              ]
            },
            "dblinks": {
              "NCBI-GeneID": [
                "947498"
              ],
              "NCBI-ProteinID": [
                "NP_414544"
              ],
              "Pasteur": [
                "thrB"
              ],
              "RegulonDB": [
                "ECK120000988"
              ],
              "ECOCYC": [
                "EG10999"
              ],
              "ASAP": [
                "ABE-0000010"
              ],
              "UniProt": [
                "P00547"
              ]
            }
          }
        ],
        "output": "eco:b0002\teco00260\tGlycine, serine and threonine metabolism\neco:b0002\teco00261\tMonobactam biosynthesis\neco:b0002\teco00270\tCysteine and methionine metabolism\neco:b0002\teco00300\tLysine biosynthesis\neco:b0002\teco01100\tMetabolic pathways\neco:b0002\teco01110\tBiosynthesis of secondary metabolites\neco:b0002\teco01120\tMicrobial metabolism in diverse environments\neco:b0002\teco01130\tBiosynthesis of antibiotics\neco:b0002\teco01230\tBiosynthesis of amino acids\neco:b0003\teco00260\tGlycine, serine and threonine metabolism\neco:b0003\teco01100\tMetabolic pathways\neco:b0003\teco01110\tBiosynthesis of secondary metabolites\neco:b0003\teco01120\tMicrobial metabolism in diverse environments\neco:b0003\teco01230\tBiosynthesis of amino acids"
      }
    ],
    "identifier": 50470951
  },
  {
    "context": [
      "How can I extract\n\n    <iframe></iframe>\n    <div class=\"text\">TEST</div>\n\nby dropping everything *before* `<iframe>` and *after* (beginning with)`<div id=\"trend\">`?",
      "Here is a solution that solves the general problem, assuming one wants to select a range of elements based on a \"linearization\" of the HTML.  This solution uses [`pup`][1] to convert HTML to JSON, and then uses [tag:jq] to perform the linearization, selection, and conversion back to HTML.",
      "def hoist:\n  .[]\n  | if type == \"object\" and has(\"children\")\n    then del(.children), (.children | hoist)\n    else .\n    end;\n\ndef indexof(condition):\n  label $out\n  | foreach .[] as $x (null; .+1;\n      if ($x|condition) then .-1, break $out else empty end)\n    // null;\n\n# Reconstitute the HTML element\ndef toHtml:\n  def k: . as $in | (keys_unsorted - [\"tag\", \"text\"])\n  | reduce .[] as $k (\"\"; . + \" \\($k)=\\\"\\($in[$k])\\\"\");\n  def t: if .text then .text else \"\" end;\n  \"<\\(.tag)\\(k)>\\(t)</\\(.tag)>\"\n  ;\n\n# Linearize and then select the desired range of elements\n[hoist]\n| indexof( .tag == \"iframe\") as $first\n| indexof( .tag == \"div\" and .id==\"trend\") as $last\n| .[$first:$last]\n| .[]\n| toHtml"
    ],
    "utterance": "Extract all elements starting from the first iframe element up to, but not including, the div element with id equal to trend.",
    "expressions": [
      "def hoist:\n  .[]\n  | if type == \"object\" and has(\"children\")\n    then del(.children), (.children | hoist)\n    else .\n    end;\n\ndef indexof(condition):\n  label $out\n  | foreach .[] as $x (null; .+1;\n      if ($x|condition) then .-1, break $out else empty end)\n    // null;\n\ndef toHtml:\n  def k: . as $in | (keys_unsorted - [\"tag\", \"text\"])\n  | reduce .[] as $k (\"\"; . + \" \\($k)=\\\"\\($in[$k])\\\"\");\n  def t: if .text then .text else \"\" end;\n  \"<\\(.tag)\\(k)>\\(t)</\\(.tag)>\"\n  ;\n\n[hoist]\n| indexof( .tag == \"iframe\") as $first\n| indexof( .tag == \"div\" and .id==\"trend\") as $last\n| .[$first:$last]\n| .[]\n| toHtml"
    ],
    "identifier": 50742300
  },
  {
    "context": [
      "How could I sort all the `items` (there is only one item above - but it's just an example) by the `.items.lasttimestamp` value, for example the value `\"lastTimestamp\": \"2018-06-07T11:59:53Z\"`?",
      "jq '[].items |= sort_by(.lastTimestamp)' input.json"
    ],
    "utterance": "Sort all elements in the items array by their lastTimestamp field in ascending order.",
    "expressions": [
      ".[].items |= sort_by(.lastTimestamp)"
    ],
    "data": [
      {
        "input": [
          {
            "apiVersion": "v1",
            "items": [
              {
                "apiVersion": "v1",
                "count": 603,
                "firstTimestamp": "2018-06-07T13:07:32Z",
                "involvedObject": {
                  "apiVersion": "v1",
                  "kind": "Pod",
                  "name": "events-db8f675c6-khm4r",
                  "namespace": "default",
                  "resourceVersion": "2989590",
                  "uid": "bd489878-6a53-11e8-9351-0e5486765cbc"
                },
                "kind": "Event",
                "lastTimestamp": "2018-06-07T16:02:52Z"
              },
              {
                "apiVersion": "v1",
                "count": 99,
                "firstTimestamp": "2018-06-06T10:07:32Z",
                "involvedObject": {
                  "apiVersion": "v1",
                  "kind": "Pod",
                  "name": "hello-db8f675c6-khm4r",
                  "namespace": "default",
                  "resourceVersion": "1234567",
                  "uid": "ab123456-6a53-11e8-9351-0e5486765cbc"
                },
                "kind": "Event",
                "lastTimestamp": "2018-06-07T11:59:53Z"
              }
            ]
          }
        ],
        "output": [
          {
            "apiVersion": "v1",
            "items": [
              {
                "apiVersion": "v1",
                "count": 99,
                "firstTimestamp": "2018-06-06T10:07:32Z",
                "involvedObject": {
                  "apiVersion": "v1",
                  "kind": "Pod",
                  "name": "hello-db8f675c6-khm4r",
                  "namespace": "default",
                  "resourceVersion": "1234567",
                  "uid": "ab123456-6a53-11e8-9351-0e5486765cbc"
                },
                "kind": "Event",
                "lastTimestamp": "2018-06-07T11:59:53Z"
              },
              {
                "apiVersion": "v1",
                "count": 603,
                "firstTimestamp": "2018-06-07T13:07:32Z",
                "involvedObject": {
                  "apiVersion": "v1",
                  "kind": "Pod",
                  "name": "events-db8f675c6-khm4r",
                  "namespace": "default",
                  "resourceVersion": "2989590",
                  "uid": "bd489878-6a53-11e8-9351-0e5486765cbc"
                },
                "kind": "Event",
                "lastTimestamp": "2018-06-07T16:02:52Z"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 50741593
  },
  {
    "context": [
      "How do I get all the **.stuff.name**s for **.mine**?",
      "For example, desired output:\r\n\r\n\t[\r\n\t\t\"Baz\",\r\n\t\t\"Foo\"\r\n\t]",
      "jq '[.mine[] as $in | .stuff[$in].name]'"
    ],
    "utterance": "Return an array of the .name properties from the .stuff object for each key listed in the mine array.",
    "expressions": [
      "[.mine[] as $in | .stuff[$in].name]"
    ],
    "data": [
      {
        "input": {
          "mine": [
            "foo",
            "baz"
          ],
          "stuff": {
            "foo": {
              "name": "Foo"
            },
            "bar": {
              "name": "Bar"
            },
            "baz": {
              "name": "Baz"
            },
            "qux": {
              "name": "Qux"
            }
          }
        },
        "output": [
          "Foo",
          "Baz"
        ]
      }
    ],
    "identifier": 50757496
  },
  {
    "context": [
      "And I'm trying to **insert** new JSON fields into the file at specific positions in the file, using **jq** such as:",
      "\"cuisine\": \"meditaranean\"\nwill become the 2nd entry, and\n\"meal\": \"lunch\"\nwill become the 4th entry. So the file after the command is like this: ...",
      "My question is how to do this with **jq**?",
      "With the help of a helper function, the task becomes trivial:\n\ndef insert_kv($key; $value; $ix):\n  to_entries\n  | .[0:$ix] + [{key: $key, value: $value}] + .[$ix:]\n  | from_entries;\n\ninsert_kv(\"cuisine\"; \"mediterranean\"; 1)\n| insert_kv(\"meal\"; \"lunch\"; 3)"
    ],
    "utterance": "Insert the field \"cuisine\": \"meditaranean\" as the 2nd entry and \"meal\": \"lunch\" as the 4th entry in an existing object.",
    "expressions": [
      "def insert_kv($key; $value; $ix): to_entries | .[0:$ix] + [{key: $key, value: $value}] + .[$ix:] | from_entries; insert_kv(\"cuisine\"; \"meditaranean\"; 1) | insert_kv(\"meal\"; \"lunch\"; 3)"
    ],
    "data": [
      {
        "input": {
          "name": "Curried Lentils and Rice",
          "ingredients": [
            {
              "quantity": "1 quart",
              "name": "beef broth",
              "type": "Misc"
            },
            {
              "quantity": "1 cup",
              "name": "dried green lentils",
              "type": "Misc"
            },
            {
              "quantity": "1/2 cup",
              "name": "basmati rice",
              "type": "Misc"
            },
            {
              "quantity": "1 tsp",
              "name": "curry powder",
              "type": "Condiments"
            },
            {
              "quantity": "1 tsp",
              "name": "salt",
              "type": "Condiments"
            }
          ],
          "steps": [
            "Bring broth to a low boil.",
            "Add curry powder and salt.",
            "Cook lentils for 20 minutes.",
            "Add rice and simmer for 20 minutes.",
            "Enjoy!"
          ],
          "timers": [
            0,
            0,
            20,
            20,
            0
          ],
          "imageURL": "http://dagzhsfg97k4.cloudfront.net/wp-content/uploads/2012/05/lentils3.jpg"
        },
        "output": {
          "name": "Curried Lentils and Rice",
          "cuisine": "meditaranean",
          "ingredients": [
            {
              "quantity": "1 quart",
              "name": "beef broth",
              "type": "Misc"
            },
            {
              "quantity": "1 cup",
              "name": "dried green lentils",
              "type": "Misc"
            },
            {
              "quantity": "1/2 cup",
              "name": "basmati rice",
              "type": "Misc"
            },
            {
              "quantity": "1 tsp",
              "name": "curry powder",
              "type": "Condiments"
            },
            {
              "quantity": "1 tsp",
              "name": "salt",
              "type": "Condiments"
            }
          ],
          "meal": "lunch",
          "steps": [
            "Bring broth to a low boil.",
            "Add curry powder and salt.",
            "Cook lentils for 20 minutes.",
            "Add rice and simmer for 20 minutes.",
            "Enjoy!"
          ],
          "timers": [
            0,
            0,
            20,
            20,
            0
          ],
          "imageURL": "http://dagzhsfg97k4.cloudfront.net/wp-content/uploads/2012/05/lentils3.jpg"
        }
      }
    ],
    "identifier": 50730050
  },
  {
    "context": [
      "so that the `\"hex\"` value of the `\"value\"` field with name `\"Encoding\"` is modified to `\"oct\"` **only** for the row that contains a field with `.name==\"id\" and .value==\"k1\"`.",
      "Using `any/2` yields a jq filter that closely matches the description of the problem in English:",
      ".rows |= map( if any(.fields[]; .name==\"id\" and .value==\"k1\")\n                  then .fields |= map(if .name == \"Encoding\"\n                                      then .value = \"oct\"\n                                      else .\n                                      end)\n                  else .\n                  end )",
      "A slightly less verbose and perhaps clearer solution is possible if we use a handy general-purpose function defined as follows:\n\ndef when(filter; action): if (filter?) // null then action else . end;\n\nWe can then write simply:\n\n.rows[] |= when( any(.fields[]; .name==\"id\" and .value==\"k1\");\n                 .fields |= map( when (.name == \"Encoding\";\n                                       .value = \"oct\")))"
    ],
    "utterance": "Change the value of the 'Encoding' field to 'oct' only for rows that contain a field with name 'id' and value 'k1'.",
    "expressions": [
      ".rows |= map( if any(.fields[]; .name==\"id\" and .value==\"k1\")\n                  then .fields |= map(if .name == \"Encoding\"\n                                      then .value = \"oct\"\n                                      else .\n                                      end)\n                  else .\n                  end )",
      "def when(filter; action): if (filter?) // null then action else . end;\n.rows[] |= when( any(.fields[]; .name==\"id\" and .value==\"k1\");\n                 .fields |= map( when (.name == \"Encoding\";\n                                       .value = \"oct\")))"
    ],
    "data": [
      {
        "input": {
          "rows": [
            {
              "fields": [
                {
                  "name": "id",
                  "value": "k1"
                },
                {
                  "name": "val",
                  "value": "2340378b211aa3d8f2d7607cbddce883b87b191d0425736641e3d308ea329718"
                },
                {
                  "name": "Encoding",
                  "value": "hex"
                }
              ]
            },
            {
              "fields": [
                {
                  "name": "id",
                  "value": "k2"
                },
                {
                  "name": "val",
                  "value": "2340378b211aa3d8f2d7607cbddce883b87b191d0425736641e3d308ea329718"
                },
                {
                  "name": "Encoding",
                  "value": "hex"
                }
              ]
            }
          ]
        },
        "output": {
          "rows": [
            {
              "fields": [
                {
                  "name": "id",
                  "value": "k1"
                },
                {
                  "name": "val",
                  "value": "2340378b211aa3d8f2d7607cbddce883b87b191d0425736641e3d308ea329718"
                },
                {
                  "name": "Encoding",
                  "value": "oct"
                }
              ]
            },
            {
              "fields": [
                {
                  "name": "id",
                  "value": "k2"
                },
                {
                  "name": "val",
                  "value": "2340378b211aa3d8f2d7607cbddce883b87b191d0425736641e3d308ea329718"
                },
                {
                  "name": "Encoding",
                  "value": "hex"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 50744629
  },
  {
    "context": [
      "I want to do the same concept in `jq`. But, there is no `in`. Here is an example with a more realistic data set, and how I can check for 2 values. In my real need I have to check for a few hundred and don't want to have all those `or`ed together.",
      "jq '.[] | select(.PrivateIpAddress == (\"172.31.6.209\", \"172.31.6.229\")) | .PrivateDnsName'",
      ".[] | select(.PrivateIpAddress | IN(\"172.31.6.209\",\"172.31.6.229\")) | .PrivateDnsName",
      "If you want to check membership in an array, say $a, simply use `IN( $a[] )`."
    ],
    "utterance": "Output the PrivateDnsName for each object where PrivateIpAddress matches any value from a specified list such as [\"172.31.6.209\", \"172.31.6.229\"].",
    "expressions": [
      ".[] | select(.PrivateIpAddress == (\"172.31.6.209\", \"172.31.6.229\")) | .PrivateDnsName",
      ".[] | select(.PrivateIpAddress | IN(\"172.31.6.209\",\"172.31.6.229\")) | .PrivateDnsName",
      ".[] | select(.PrivateIpAddress | IN($a[])) | .PrivateDnsName"
    ],
    "data": [
      {
        "input": [
          {
            "PrivateDnsName": "ip-172-31-6-209.us-west-2.compute.internal",
            "PrivateIpAddress": "172.31.6.209"
          },
          {
            "PrivateDnsName": "ip-172-31-6-219.us-west-2.compute.internal",
            "PrivateIpAddress": "172.31.6.219"
          },
          {
            "PrivateDnsName": "ip-172-31-6-229.us-west-2.compute.internal",
            "PrivateIpAddress": "172.31.6.229"
          },
          {
            "PrivateDnsName": "ip-172-31-6-239.us-west-2.compute.internal",
            "PrivateIpAddress": "172.31.6.239"
          }
        ],
        "output": [
          "ip-172-31-6-209.us-west-2.compute.internal",
          "ip-172-31-6-229.us-west-2.compute.internal"
        ]
      }
    ],
    "identifier": 50750688
  },
  {
    "context": [
      "I have a sample json response as shown below which i am trying to parse using jq in shell script.`[{\"id\":1,\"notes\":\"Demo1\\nDemo2\"}]`",
      "value=($(curl $URL | jq -r '[].notes'))",
      "When I echo \"$value\" I only get Demo1. How to get the exact value: Demo1\\nDemo2 ?",
      "To instead get it as a simple string, remove the parens from `value=(..)`:",
      "value=$(printf '%s' \"$data\" | jq -r '.[].notes')",
      "echo \"$value\"",
      "Demo1\nDemo2"
    ],
    "utterance": "Extract the value of the 'notes' field, preserving its linebreaks, from the first object in the data.",
    "expressions": [
      ".[].notes"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "notes": "Demo1\nDemo2"
          }
        ],
        "output": "Demo1\nDemo2"
      }
    ],
    "identifier": 50770638
  },
  {
    "context": [
      "I have a sample json response as shown below which i am trying to parse using jq in shell script.`[{\"id\":1,\"notes\":\"Demo1\\nDemo2\"}]`",
      "I am getting an error when trying to access individual variables",
      "idval=$(echo $value | jq -r '[].id'))",
      "You need to quote `$value`:",
      "echo \"$value\" | jq -r '[].id' ",
      "1"
    ],
    "utterance": "Extract the value of the 'id' field from an array with one object where the input is stored in a shell variable.",
    "expressions": [
      ".[].id"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "notes": "Demo1\nDemo2"
          }
        ],
        "output": 1
      }
    ],
    "identifier": 50788939
  },
  {
    "context": [
      "The main array is `results` and I would like to pull the field `name` and then the fields `indicator` and `type` from the `indicators` array.",
      "How would I pull the `name` field and assign it to each `indicator` in that specific array?",
      "jq -r '.results[] | .name as $n | .indicators[] | [$n, .type, .indicator] | @csv' file.json",
      ".results[] | .name as $name | .indicators[] | [$name, .type, .indicator] | @csv",
      "$ jq -r '.results[] | foreach .indicators[] as $i ({name}; .; [.name,$i.type,$i.indicator]) | @csv'"
    ],
    "utterance": "For each object in the results array, output the name along with type and indicator for every entry in that object's indicators array, as CSV.",
    "expressions": [
      ".results[] | .name as $n | .indicators[] | [$n, .type, .indicator] | @csv",
      ".results[] | .name as $name | .indicators[] | [$name, .type, .indicator] | @csv",
      ".results[] | foreach .indicators[] as $i ({name}; .; [.name, $i.type, $i.indicator]) | @csv"
    ],
    "data": [
      {
        "input": {
          "count": 6918,
          "next": "https://otx.alienvault.com/api/v1/pulses/subscribed?limit=50&page=2",
          "results": [
            {
              "industries": [],
              "tlp": "white",
              "description": "...",
              "created": "2018-05-31T12:25:14.636000",
              "tags": [],
              "modified": "2018-05-31T12:25:14.636000",
              "author_name": "AlienVault",
              "public": 1,
              "extract_source": [],
              "references": [
                "https://www.proofpoint.com/us/threat-insight/post/thief-night-new-nocturnal-stealer-grabs-data-cheap"
              ],
              "targeted_countries": [],
              "indicators": [
                {
                  "indicator": "http://nctrnl.us/",
                  "description": "",
                  "created": "2018-05-31T12:25:16",
                  "title": "",
                  "content": "",
                  "type": "URL",
                  "id": 981584318
                },
                {
                  "indicator": "http://nctrnl.us/ara.exe",
                  "description": "",
                  "created": "2018-05-31T12:25:16",
                  "title": "",
                  "content": "",
                  "type": "URL",
                  "id": 981584319
                }
              ],
              "more_indicators": false,
              "revision": 1,
              "adversary": "",
              "id": "5b0fe9aa8bc6a5498565929a",
              "name": "Thief in the night: New Nocturnal Stealer grabs data on the cheap"
            }
          ]
        },
        "output": [
          "\"Thief in the night: New Nocturnal Stealer grabs data on the cheap\",\"URL\",\"http://nctrnl.us/\"",
          "\"Thief in the night: New Nocturnal Stealer grabs data on the cheap\",\"URL\",\"http://nctrnl.us/ara.exe\""
        ]
      }
    ],
    "identifier": 50627757
  },
  {
    "context": [
      "I am trying to replace \"${FOO}\" with \"BAR\" (please note: \"${FOO}\" is NOT a shell variable - this is how it appears in the json, and I have no control over the json)",
      "However, if I want to programatically assign the matching value (`MYVAR=FOO` in this case),I cannot get it to work e.g.",
      "Thus if your real goal is to change occurrences of the JSON string\n\"${FOO}\" with \"BAR\", where FOO is to be specified programmatically,\nyou will have to adopt a different strategy. This\nwould work:",
      "echo '{ \"name\": \"${FOO}\" }' |\n  jq -c --arg MYVAR FOO --arg MYVALUE BAR '\n    if .name == \"${\\($MYVAR)}\" then .name = $MYVALUE else . end'"
    ],
    "utterance": "Replace the value of the 'name' property with 'BAR' when it exactly matches the string pattern '${FOO}', where 'FOO' is a programmatically supplied variable.",
    "expressions": [
      "if .name == \"${\\($MYVAR)}\" then .name = $MYVALUE else . end"
    ],
    "data": [
      {
        "input": {
          "name": "${FOO}"
        },
        "output": {
          "name": "BAR"
        }
      }
    ],
    "identifier": 50809580
  },
  {
    "context": [
      "my simple `jq` queries like\n\n    jq '.[\"recipes\"][] | select(.l | test(\"ill\"))' < jsonfile\n\nstopped returning all of the results they should",
      "started printing this error message:\n\n    jq: error (at <stdin>:3943): null (null) cannot be matched, as it is not a string",
      "entries in the \"recipes\" section often do not contain an \"l\" attribute, and `jq` will cease processing as soon as it encounters one that does not.",
      "I fixed the error ... by testing for the presence of the attribute first:\n\n    jq '[\"recipes\"][] | select(has(\"l\") and (.l | test(\"ill\")))' < jsonfile"
    ],
    "utterance": "Find all objects in the recipes array where the attribute l exists and its value matches the substring 'ill'.",
    "expressions": [
      ".[\"recipes\"][] | select(has(\"l\") and (.l | test(\"ill\")))"
    ],
    "data": [
      {
        "input": {
          "levels": [
            {
              "a": 1,
              "b": false,
              "c": "2012",
              "d": "2017"
            },
            {
              "a": 2,
              "b": true,
              "c": "2013",
              "d": "9999"
            }
          ],
          "costs": [
            {
              "e": 12,
              "f": "foo",
              "g": "blarg",
              "h": "2015",
              "i": "2018"
            },
            {
              "e": -3,
              "f": "foo",
              "g": "glorb",
              "h": "2013",
              "i": "9999"
            }
          ],
          "recipes": [
            {
              "j": "BAZ",
              "k": [
                "blarg",
                "glorb",
                "bleeg"
              ],
              "l": "dill",
              "m": "2016",
              "n": "2017"
            },
            {
              "j": "BAZ",
              "k": [
                "blarg",
                "bleeg"
              ],
              "l": "dill",
              "m": "2017",
              "n": "9999"
            },
            {
              "j": "QUX",
              "k": [
                "qux"
              ],
              "m": "2017",
              "n": "9999"
            }
          ]
        },
        "output": [
          {
            "j": "BAZ",
            "k": [
              "blarg",
              "glorb",
              "bleeg"
            ],
            "l": "dill",
            "m": "2016",
            "n": "2017"
          },
          {
            "j": "BAZ",
            "k": [
              "blarg",
              "bleeg"
            ],
            "l": "dill",
            "m": "2017",
            "n": "9999"
          }
        ]
      }
    ],
    "identifier": 50806009
  },
  {
    "context": [
      "I want to have a count of the rows with respect to the value in field one, like:\n\n    249449 : 2\n    249448 : 1\n    249447 : 1\n    249443 : 1\n\nHow can I get that?",
      "You can use the [jq][1] command line tool to interpret JSON data. `uniq -c` counts the number of occurences.\n\n    % jq .field1 < $INPUTFILE | sort | uniq -c\n          1 249443\n          1 249447\n          1 249448\n          2 249449",
      "Here's an efficient `jq`-only solution:\n\n    reduce inputs.field1 as $x ({}; .[$x|tostring] += 1)\n    | to_entries[]\n    | \"\\(.key) : \\(.value)\"\n\nInvocation: `jq -nrf program.jq input.json`",
      "Of course if an object-representation of the counts is satisfactory, then\none could simply write: \n\n    jq -n 'reduce inputs.field1 as $x ({}; .[$x|tostring] += 1)' input.json"
    ],
    "utterance": "Count the number of rows for each unique value in field1 and output the counts per value.",
    "expressions": [
      ".field1 | sort | uniq -c",
      "reduce inputs.field1 as $x ({}; .[$x|tostring] += 1) | to_entries[] | \"\\(.key) : \\(.value)\"",
      "reduce inputs.field1 as $x ({}; .[$x|tostring] += 1)"
    ],
    "data": [
      {
        "input": [
          {
            "field1": 249449,
            "field2": 116895,
            "field3": 1,
            "field4": "apple",
            "field5": 42,
            "field6": "2019-07-01T00:00:10",
            "metadata": "",
            "frontend": ""
          },
          {
            "field1": 249448,
            "field2": 116895,
            "field3": 1,
            "field4": "apple",
            "field5": 42,
            "field6": "2019-07-01T00:00:10",
            "metadata": "",
            "frontend": ""
          },
          {
            "field1": 249447,
            "field2": 116895,
            "field3": 1,
            "field4": "apple",
            "field5": 42,
            "field6": "2019-07-01T00:00:10",
            "metadata": "",
            "frontend": ""
          },
          {
            "field1": 249443,
            "field2": 116895,
            "field3": 1,
            "field4": "apple",
            "field5": 42,
            "field6": "2019-07-01T00:00:10",
            "metadata": "",
            "frontend": ""
          },
          {
            "field1": 249449,
            "field2": 116895,
            "field3": 1,
            "field4": "apple",
            "field5": 42,
            "field6": "2019-07-01T00:00:10",
            "metadata": "",
            "frontend": ""
          }
        ],
        "output": [
          "249443 : 1",
          "249447 : 1",
          "249448 : 1",
          "249449 : 2"
        ]
      }
    ],
    "identifier": 50773151
  },
  {
    "context": [
      "timestamp.json contains a few hundred of the below in the file. I need to reference every single one and pull out any that older than 45 days.",
      "cat $_fileformated | jq -r --arg days \"$days\" 'select(.Timestamp | . == null or fromdateiso8601? < \"$days\" ) .serverrname' >> $filereport",
      "With your sample input and days=1524953907, the following query:",
      "jq --argjson days $days '\n  select(.Timestamp | select(fromdateiso8601 > $days)).servername'\n",
      "One can use `--arg days $days` but then you'd have to convert the string to a number, e.g. by `$days|tonumber`"
    ],
    "utterance": "Extract all servername values where the Timestamp is older than the value stored in a shell variable representing seconds since the epoch, treating entries with null Timestamps as matching.",
    "expressions": [
      "jq --argjson days \"$days\" 'select(.Timestamp == null or (fromdateiso8601? < $days)) | .servername'",
      "jq --arg days \"$days\" 'select(.Timestamp == null or (fromdateiso8601? < ($days|tonumber))) | .servername'"
    ],
    "data": [
      {
        "input": {
          "servername": "xxxxxxxx",
          "Timestamp": "2018-06-12T13:41:08Z"
        },
        "output": "xxxxxxxx"
      }
    ],
    "identifier": 50826242
  },
  {
    "context": [
      "I am struggling to merge two JSON arrays with jq, because I would like to remove duplicate keys in merged objects:",
      "file1.json :\n    [\n      {\"a\": 1, \"value\": 11},\n      {\"b\": 2},\n      {\"c\": 3}\n    ]",
      "file2.json :\n    [\n      {\"a\": 4, \"value\": 44},\n      {\"b\": 5},\n      {\"d\": 6}\n    ]",
      "Expected result:\n    [\n      {\"a\": 4, \"value\": 44},\n      {\"b\": 5},\n      {\"c\": 3},\n      {\"d\": 6}\n    ]",
      "jq --slurpfile file2 file2.json \\\n'. + $file2[] | map(to_entries) | flatten \n | group_by(.key) | map(.[-1] | {(.key): .value})' file1.json",
      "[INDEX( add[] | to_entries; (.[0] | .key) )[]|from_entries ]",
      "Invocation:\n    jq -scf program.jq file1.json file2.json"
    ],
    "utterance": "Merge two arrays of objects so that for objects with duplicate keys, only the last occurrence (from the second array) is kept; the result should be an array combining all objects with unique keys, with later objects overwriting earlier ones.",
    "expressions": [
      "jq --slurpfile file2 file2.json '. + $file2[] | map(to_entries) | flatten | group_by(.key) | map(.[-1] | {(.key): .value})' file1.json",
      "[INDEX( add[] | to_entries; (.[0] | .key) )[]|from_entries ]"
    ],
    "data": [
      {
        "input": [
          [
            {
              "a": 1,
              "value": 11
            },
            {
              "b": 2
            },
            {
              "c": 3
            }
          ],
          [
            {
              "a": 4,
              "value": 44
            },
            {
              "b": 5
            },
            {
              "d": 6
            }
          ]
        ],
        "output": [
          {
            "a": 4,
            "value": 44
          },
          {
            "b": 5
          },
          {
            "c": 3
          },
          {
            "d": 6
          }
        ]
      }
    ],
    "identifier": 50818215
  },
  {
    "context": [
      "I need to get the AMI ID and the AMI Name. How can I do that in one command?",
      "For the record, here's how to combine the two jq commands:",
      "jq -r '.Images[] | (.ImageId, .Name)'"
    ],
    "utterance": "List the ID and name of each AMI, showing both values per image.",
    "expressions": [
      ".Images[] | (.ImageId, .Name)"
    ],
    "identifier": 50845727
  },
  {
    "context": [
      "How can I get only `Google LLC` ?",
      "curl cli.fyi/8.8.8.8 | jq -r .data.organization",
      "That would give you the bare string:\r\n\r\n    Google LLC"
    ],
    "utterance": "Extract the value of the organisation field from the data object where it equals 'Google LLC'.",
    "expressions": [
      ".data.organisation",
      "-r .data.organisation"
    ],
    "data": [
      {
        "input": {
          "type": "IP Address",
          "data": {
            "organisation": "Google LLC",
            "country": "United States",
            "countryCode": "US",
            "continent": "North America",
            "latitude": "37.751",
            "longitude": "-97.822"
          }
        },
        "output": "Google LLC"
      }
    ],
    "identifier": 50843960
  },
  {
    "context": [
      "My program requires to get value for properties selected randomly, so the property name is not known before runtime (hence the reason for trying to use parameters)",
      "jq --arg namearg \"$1\" '.[$namearg]' < json",
      "getProperty \"first.name\"",
      "\"Adam\"",
      "getProperty \"last.name\"",
      "\"Eve\""
    ],
    "utterance": "Retrieve the value of a property when the property name is provided as a shell argument and may contain dots.",
    "expressions": [
      "jq --arg namearg \"$1\" '.[$namearg]'"
    ],
    "data": [
      {
        "input": {
          "first.name": "Adam",
          "last.name": "Eve"
        },
        "output": "Adam"
      }
    ],
    "identifier": 50849591
  },
  {
    "context": [
      "I have the following JSON snippet:",
      "{\n  \"a\": [ 1, \"a:111\" ],\n  \"b\": [ 2, \"a:111\", \"irrelevant\" ],\n  \"c\": [ 1, \"a:222\" ],\n  \"d\": [ 1, \"b:222\" ],\n  \"e\": [ 2, \"b:222\", \"irrelevant\"]\n}",
      "and I would like to swap the key with the second value of the array and accumulate keys with the same value, discarding possible values that come after the second one:",
      "{ \"a:111\": [ [ 1, \"a\" ], [ 2, \"b\" ] ],\n  \"a:222\": [ [ 1, \"c\" ] ],\n  \"b:222\": [ [ 1, \"d\" ], [ 2, \"e\" ] ]\n}",
      "Short **`jq`** approach:",
      "jq 'reduce to_entries[] as $o ({};\n    .[$o.value[1]] += [[$o.value[0], $o.key]])' input.json"
    ],
    "utterance": "Swap each object's key with the array's second element, grouping by this value so that for each group, collect arrays of the first element and the original key, discarding other array values.",
    "expressions": [
      "reduce to_entries[] as $o ({};\n    .[$o.value[1]] += [[$o.value[0], $o.key]])"
    ],
    "data": [
      {
        "input": {
          "a": [
            1,
            "a:111"
          ],
          "b": [
            2,
            "a:111",
            "irrelevant"
          ],
          "c": [
            1,
            "a:222"
          ],
          "d": [
            1,
            "b:222"
          ],
          "e": [
            2,
            "b:222",
            "irrelevant"
          ]
        },
        "output": {
          "a:111": [
            [
              1,
              "a"
            ],
            [
              2,
              "b"
            ]
          ],
          "a:222": [
            [
              1,
              "c"
            ]
          ],
          "b:222": [
            [
              1,
              "d"
            ],
            [
              2,
              "e"
            ]
          ]
        }
      }
    ],
    "identifier": 50834871
  },
  {
    "context": [
      "Basically I want to return all results where Diff is greater than a non-zero Threshold. So in this case:\r\n\r\n    {\r\n      \"A\": \"moo\",\r\n      \"B\": \"goo\",\r\n      \"Diff\": \"5000\",\r\n      \"Threshold\": \"2000\"\r\n    }",
      "You're just missing some parentheses.  Compare:\r\n\r\n    select((.Threshold|tonumber) > 0 and\r\n           (.Diff|tonumber) > (.Threshold|tonumber))",
      "Or avoiding the double-conversion:\r\n\r\n    select( (.Threshold|tonumber) as $t\r\n            | $t > 0 and (.Diff|tonumber) > $t )",
      "You could also simplify the entire program a bit:\r\n\r\n    .results[]\r\n    | select( ((.Threshold // 0) | tonumber) as $t \r\n              | $t > 0 and (.Diff|tonumber) > $t )"
    ],
    "utterance": "Return all objects where Diff is greater than a non-zero Threshold.",
    "expressions": [
      ".results[] | select((.Threshold|tonumber) > 0 and (.Diff|tonumber) > (.Threshold|tonumber))",
      ".results[] | select((.Threshold|tonumber) as $t | $t > 0 and (.Diff|tonumber) > $t)",
      ".results[] | select(((.Threshold // 0) | tonumber) as $t | $t > 0 and (.Diff|tonumber) > $t)"
    ],
    "data": [
      {
        "input": {
          "preview": false,
          "init_offset": 0,
          "messages": [],
          "fields": [
            {
              "name": "A"
            },
            {
              "name": "B"
            },
            {
              "name": "Diff"
            },
            {
              "name": "Threshold"
            }
          ],
          "results": [
            {
              "A": "foo",
              "B": "bar",
              "Diff": "1095",
              "Threshold": "1200"
            },
            {
              "A": "baz",
              "B": "bux",
              "Diff": "81793",
              "Threshold": "0"
            },
            {
              "A": "quux",
              "B": "quuz",
              "Diff": "194"
            },
            {
              "A": "moo",
              "B": "goo",
              "Diff": "5000",
              "Threshold": "2000"
            }
          ]
        },
        "output": {
          "A": "moo",
          "B": "goo",
          "Diff": "5000",
          "Threshold": "2000"
        }
      }
    ],
    "identifier": 50843611
  },
  {
    "context": [
      "**Input :** \r\n\r\n    { \"names\" : [\"name1\",\"name2\",\"name3\",\"pat_name4\"] }",
      "**Needed output :**\r\n\r\n    { \"names\" : [\"name1\",\"name2\",\"name3\"] }",
      "to filter out all names starting with `pat_`",
      "jq -c '.names |= map(select(test(\"^pat_\")|not))'",
      "produces:\r\n\r\n    {\"names\":[\"name1\",\"name2\",\"name3\"]}"
    ],
    "utterance": "Remove all elements from the names array whose value starts with pat_",
    "expressions": [
      ".names |= map(select(test(\"^pat_\")|not))"
    ],
    "data": [
      {
        "input": {
          "names": [
            "name1",
            "name2",
            "name3",
            "pat_name4"
          ]
        },
        "output": {
          "names": [
            "name1",
            "name2",
            "name3"
          ]
        }
      }
    ],
    "identifier": 50882417
  },
  {
    "context": [
      "I have the following json and need to filter keys based on a keyword and print out the whole object (not just the key) or certain key/value pairs.",
      "cat timers.json| jq '.timers | keys[] | select(contains(\"KeywordA\")) '",
      "the trick is to select the objects, not the keys, like so:",
      ".timers | with_entries( select(.key|contains(\"KeywordA\") ) )",
      "With your (modified) input, this produces:",
      "{\n  \"timerWithAKeywordAPlusBlah\": {\n    \"count\": 1,\n    \"max\": 0,\n    \"min\": 0\n  },\n  \"timerWithAKeywordAPlusBlahBlah\": {\n    \"count\": 2385,\n    \"max\": 2,\n    \"min\": 1\n  }\n}"
    ],
    "utterance": "Return only the key-value pairs from the 'timers' object whose keys contain 'KeywordA', including the full nested object for each.",
    "expressions": [
      ".timers | with_entries( select(.key|contains(\"KeywordA\") ) )"
    ],
    "data": [
      {
        "input": {
          "timers": {
            "timerWithAKeywordAPlusBlah": {
              "count": 1,
              "max": 0,
              "min": 0
            },
            "timerWithAKeywordB": {
              "count": 2,
              "max": 0
            },
            "timerWithAKeywordAPlusBlahBlah": {
              "count": 2385,
              "max": 2,
              "min": 1
            }
          }
        },
        "output": {
          "timerWithAKeywordAPlusBlah": {
            "count": 1,
            "max": 0,
            "min": 0
          },
          "timerWithAKeywordAPlusBlahBlah": {
            "count": 2385,
            "max": 2,
            "min": 1
          }
        }
      }
    ],
    "identifier": 50864894
  },
  {
    "context": [
      "With the following JSON, how do I write a script using JQ to filter for a regex where i want the result to be only Address's with numbers as the first character.",
      "how do i add to this to filter for the regex expression I want (which is \\A[0-9])",
      "If you tacked the following filter onto the one you already have, then you'd get the output shown below:",
      "map(select(.Address | test(\"^[0-9]\")))",
      "For robustness, you might like to consider adding `?` after the test:",
      "map(select(.Address | test(\"^[0-9]\")?))",
      "You might like to consider:",
      ".[].payload.address | select(test(\"^[0-9]\")?) | {Address: .}",
      "$ echo '[{\"Address\": \"The Sq\", \"n\": 1}, {\"Address\": \"1 Bridge Rd\", \"n\": 2}]' | jq '.[] | select(.Address|test(\"^[0-9]\"))'"
    ],
    "utterance": "Filter only objects where the Address field starts with a number.",
    "expressions": [
      "map(select(.Address | test(\"^[0-9]\")))",
      "map(select(.Address | test(\"^[0-9]\")?))",
      ".[].payload.address | select(test(\"^[0-9]\")?) | {Address: .}",
      ".[] | select(.Address | test(\"^[0-9]\"))"
    ],
    "data": [
      {
        "input": [
          {
            "Address": "The Sq"
          },
          {
            "Address": "1 Bridge Rd"
          }
        ],
        "output": [
          {
            "Address": "1 Bridge Rd"
          }
        ]
      }
    ],
    "identifier": 50868203
  },
  {
    "context": [
      "Looking to find the object count in the InUseBy element.",
      "`[.CertificateArn, .InUseBy | length]` applies length to all items, how do I limit it to `InUseBy`",
      "You need to use parentheses:\r\n\r\n    [.CertificateArn, (.InUseBy | length)]"
    ],
    "utterance": "Return an array containing the CertificateArn and the count of elements in InUseBy.",
    "expressions": [
      "[.CertificateArn, (.InUseBy | length)]"
    ],
    "identifier": 50913090
  },
  {
    "context": [
      "I need to get only x values like \r\n\r\n    a\r\n    b\r\n    c\r\n\r\nHow can I do that?",
      "cat input.json | jq '.x[]'",
      "$ jq '.x[]' < input.json\r\n    \"a\"\r\n    \"b\"\r\n    \"c\"",
      "$ jq -r '.x[]' < input.json\r\n    a\r\n    b\r\n    c"
    ],
    "utterance": "List all values of the x key as separate lines.",
    "expressions": [
      ".x[]",
      ".x[] | @text",
      ".x[] | tostring",
      "-r .x[]"
    ],
    "data": [
      {
        "input": {
          "x": [
            "a",
            "b",
            "c"
          ],
          "y": [
            "d",
            "e"
          ]
        },
        "output": [
          "a",
          "b",
          "c"
        ]
      }
    ],
    "identifier": 50909616
  },
  {
    "context": [
      "I want to process `docker inspect <container1> <container2>` out to retrieve via `jq` command exposed ports and IPAddresses assigned to defined networks.",
      "Expected output",
      "{",
      "\t# .[].Name",
      "\t\"/prometheus_prometheus_1\": [",
      "\t\t[",
      "\t\t\t# .[].Config.ExposedPorts",
      "\t\t\t\"9090/tcp\"",
      "\t\t],",
      "\t\t{",
      "\t\t\t# key \t= .[].NetworkSettings.Networks.<index>",
      "\t\t\t# value = .[].NetworkSettings.Networks[].IPAddress",
      "\t\t\t\"prometheus_internal\": \"172.21.0.4\",",
      "\t\t\t\"system-information\": \"172.28.0.2\"",
      "\t\t}",
      "\t]",
      "}",
      "jq '.[] | {(.Name) : [(.Config.ExposedPorts | keys),\n                          (.NetworkSettings.Networks | to_entries\n                           | map({(.key): .value.IPAddress}) | add)\n                         ]\n              }' input",
      "The output:",
      "{",
      "  \"/prometheus_prometheus_1\": [",
      "    [",
      "      \"9090/tcp\"",
      "    ],",
      "    {",
      "      \"prometheus_internal\": \"172.21.0.4\",",
      "      \"system-information\": \"172.28.0.2\"",
      "    }",
      "  ]",
      "}"
    ],
    "utterance": "Return an object with each container's Name as the key, and for each, an array containing a list of exposed ports and a mapping of network names to their assigned IP addresses.",
    "expressions": [
      ".[] | {(.Name) : [(.Config.ExposedPorts | keys), (.NetworkSettings.Networks | to_entries | map({(.key): .value.IPAddress}) | add)]}"
    ],
    "data": [
      {
        "input": [
          {
            "Id": "c2f86bce68441f50f973ae89a835d052e74c083e35b5438f3cec2497bcac79fa",
            "Name": "/prometheus_prometheus_1",
            "Config": {
              "ExposedPorts": {
                "9090/tcp": {}
              }
            },
            "NetworkSettings": {
              "Networks": {
                "prometheus_internal": {
                  "IPAddress": "172.21.0.4"
                },
                "system-information": {
                  "IPAddress": "172.28.0.2"
                }
              }
            }
          }
        ],
        "output": {
          "/prometheus_prometheus_1": [
            [
              "9090/tcp"
            ],
            {
              "prometheus_internal": "172.21.0.4",
              "system-information": "172.28.0.2"
            }
          ]
        }
      }
    ],
    "identifier": 50824913
  },
  {
    "context": [
      "jq -Rn '{ \"hosts\": [inputs | split(\"\\\\s+\"; \"g\") | select(length > 0 and .[0] != \"\") | {(.[0]): .[1:]} ] | add }' <input.txt",
      "Which yields as output: {\n  \"hosts\": {\n    \"host_1\": [\n      \"1\",\n      \"2\",\n      \"3\"\n    ],\n    \"host_2\": [\n      \"2\",\n      \"3\",\n      \"4\"\n    ],\n    \"host-with-dashes\": [\n      \"3\",\n      \"4\",\n      \"5\"\n    ],\n    \"host-with-no-addresses\": []\n  }\n}"
    ],
    "utterance": "Transform a whitespace-delimited list of hostnames and their addresses into an object with each hostname as key and a list of addresses as its value, handling hostnames with dashes and empty address lists.",
    "expressions": [
      "jq -Rn '{ \"hosts\": [inputs | split(\"\\\\s+\"; \"g\") | select(length > 0 and .[0] != \"\") | {(.[0]): .[1:]} ] | add }' <input.txt"
    ],
    "data": [
      {
        "input": "host_1 1 2 3\nhost_2 2 3 4\nhost-with-dashes 3 4 5\nhost-with-no-addresses\n",
        "output": {
          "hosts": {
            "host_1": [
              "1",
              "2",
              "3"
            ],
            "host_2": [
              "2",
              "3",
              "4"
            ],
            "host-with-dashes": [
              "3",
              "4",
              "5"
            ],
            "host-with-no-addresses": []
          }
        }
      }
    ],
    "identifier": 50917660
  },
  {
    "context": [
      "I have text data which looks like (space separated snippet):",
      "Using shell script or command line (preferably using jq) want to convert this to one nested json  which would look like:",
      "The appropriate approach to solving the problem using jq is essentially the same as would be used using `awk`: for each input line (except the first), parse it and emit the corresponding JSON object.",
      "def parse:\n  [splits(\" +\")]",
      "| {(.[0]) : {type: .[1],\n                   input: (.[2] | fromjson),\n                   config: { file: .[3],\n                               th: .[4] }} };",
      "{ dets: [inputs | parse] | add }"
    ],
    "utterance": "Convert space-separated text lines with a header to a nested object keyed by the first column, with specified fields grouped and arrays parsed from string representations; skip the header.",
    "expressions": [
      "def parse: [splits(\" +\")] | {(.[0]) : {type: .[1], input: (.[2] | fromjson), config: { file: .[3], th: .[4] }} }; { dets: [inputs | parse] | add }"
    ],
    "data": [
      {
        "input": "name type input file th repeatNumber\nS1 class [12,7,6,19] sfile1 -10 2\nS2 class [12,7,6,19] sfile2 -5 1\nS3 bottom [12,7,16] sfile3 -15 1",
        "output": {
          "dets": {
            "S1": {
              "type": "class",
              "input": [
                12,
                7,
                6,
                19
              ],
              "config": {
                "file": "sfile1",
                "th": "-10"
              }
            },
            "S2": {
              "type": "class",
              "input": [
                12,
                7,
                6,
                19
              ],
              "config": {
                "file": "sfile2",
                "th": "-5"
              }
            },
            "S3": {
              "type": "bottom",
              "input": [
                12,
                7,
                16
              ],
              "config": {
                "file": "sfile3",
                "th": "-15"
              }
            }
          }
        }
      }
    ],
    "identifier": 50884993
  },
  {
    "context": [
      "You could use [jq][1] to encode the contents of the .svg file as a JSON string, e.g.",
      "jq -Rs . media.svg",
      "you can use jq's `@base64` filter.",
      "diff FILENAME <(jq -Rs @base64 FILENAME | jq -r @base64d)"
    ],
    "utterance": "Convert the contents of a file into a JSON string or base64-encoded string using different filters.",
    "expressions": [
      "jq -Rs . media.svg",
      "jq -Rs @base64 media.svg"
    ],
    "data": [
      {
        "input": "<svg xmlns=\"http://www.w3.org/2000/svg\"></svg>",
        "output": "\"<svg xmlns=\\\"http://www.w3.org/2000/svg\\\"></svg>\""
      },
      {
        "input": "<svg xmlns=\"http://www.w3.org/2000/svg\"></svg>",
        "output": "\"PHN2ZyB4bWxucz1cImh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnXCI+PC9zdmc+\""
      }
    ],
    "identifier": 50929274
  },
  {
    "context": [
      "Here using jq first i want to extract all score values and then check if any score value in the object is greater than or equal to requiredValue.",
      "Suppose if requiredValue is 5 then jq query should return false and if requiredValue is 2 it should return true.",
      "jq --argjson requiredValue $requiredValue ' any(.[].score; . >= $requiredValue)' <<< \"$x\"",
      "The result:\n\n    false"
    ],
    "utterance": "Check if any object's score value is greater than or equal to a given requiredValue, returning true or false accordingly.",
    "expressions": [
      "any(.[].score; . >= $requiredValue)"
    ],
    "data": [
      {
        "input": [
          {
            "score": 1
          },
          {
            "score": 2
          },
          {
            "score": 3
          }
        ],
        "output": false
      }
    ],
    "identifier": 50933785
  },
  {
    "context": [
      "I have a JSON structure that has repeated keys per message. I would like to combine these into one array per message.",
      "However, what I want is to output: [{ \"id\": 1, \"access_type\": [\"drop|select\"] }, { \"id\": 2, \"access_type\": [\"drop|update\"] }]",
      "The values could be 'drop' and 'select', but equally could be anything, so I don't want to hard code these.",
      "Now it's a simple matter to tweak the above filter so as to produce the desired format:",
      "[.[] | {id, access_type: [.PolicyItems[].accesses[].type]} | .access_type |= [join(\"|\")] ]",
      "Or equivalently, the one-liner:",
      "map({id, access_type: [[.PolicyItems[].accesses[].type] | join(\"|\")]})"
    ],
    "utterance": "For each object, combine all 'type' values from every nested 'accesses' array within its PolicyItems property into a single string separated by '|' and return them as an array in a field named 'access_type' for each id.",
    "expressions": [
      "[.[] | {id, access_type: [.PolicyItems[].accesses[].type]} | .access_type |= [join(\"|\")] ]",
      "map({id, access_type: [[.PolicyItems[].accesses[].type] | join(\"|\")]})"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "PolicyItems": [
              {
                "accesses": [
                  {
                    "isAllowed": true,
                    "type": "drop"
                  },
                  {
                    "isAllowed": true,
                    "type": "select"
                  }
                ],
                "groups": [],
                "users": [
                  "admin"
                ]
              }
            ]
          },
          {
            "id": 2,
            "PolicyItems": [
              {
                "accesses": [
                  {
                    "isAllowed": true,
                    "type": "drop"
                  },
                  {
                    "isAllowed": true,
                    "type": "update"
                  }
                ],
                "groups": [],
                "users": [
                  "admin",
                  "admin2"
                ]
              }
            ]
          }
        ],
        "output": [
          {
            "id": 1,
            "access_type": [
              "drop|select"
            ]
          },
          {
            "id": 2,
            "access_type": [
              "drop|update"
            ]
          }
        ]
      }
    ],
    "identifier": 50917916
  },
  {
    "context": [
      "jq -rc '.Latitude + \" \" +.Longitude' /usr/location/archive/location_1806181400.json | while read -r Latitude Longitude; do curl https://maps.googleapis.com/maps/api/geocode/json?latlng=$Latitude,$Longitude&key=APIKEYHERE done",
      "You could try: jq -r '.Data[] | \"\\(.Latitude) \\(.Longitude)\"' /usr/location/archive/location_1806181400.json | while read l g; do curl \"https://maps.googleapis.com/maps/api/geocode/json?latlng=${l},${g}&key=APIKEYHERE\"; done",
      "The problem is with your jq filter, you need to do an interpolation logic as below to put the values out in a CSV format, which you can parse out using a shell loop. jq -r '(.Data[] | \"\\(.Latitude),\\(.Longitude)\")'"
    ],
    "utterance": "Extract all pairs of Latitude and Longitude values from the Data array, outputting each pair on a separate line.",
    "expressions": [
      ".Data[] | \"\\(.Latitude) \\(.Longitude)\"",
      ".Data[] | \"\\(.Latitude),\\(.Longitude)\""
    ],
    "data": [
      {
        "input": {
          "Data": [
            {
              "Date": "2018-06-19T06:02:12+02:00",
              "Latitude": 46.54225,
              "Longitude": 17.13874,
              "Type": "GPS",
              "Speed(mph)": 0,
              "Speed(km/h)": 0,
              "Direction": null,
              "Altitude(ft)": 406,
              "Altitude(m)": 124,
              "Accuracy": 50
            },
            {
              "Date": "2018-06-19T06:59:49+02:00",
              "Latitude": 46.53973,
              "Longitude": 17.06964,
              "Type": "GPS",
              "Speed(mph)": 1,
              "Speed(km/h)": 2,
              "Direction": 208,
              "Altitude(ft)": 377,
              "Altitude(m)": 115,
              "Accuracy": 10
            }
          ]
        },
        "output": [
          "46.54225 17.13874",
          "46.53973 17.06964"
        ]
      }
    ],
    "identifier": 50922765
  },
  {
    "context": [
      "i am looking to count the occurrences of \"Dog\" only when it is in the \"Pets\" datafield/key",
      "count(.. | objects | (.Pets // []) | flatten[] | select(.==\"Dog\"))"
    ],
    "utterance": "Count how many times the value \"Dog\" appears in all elements under the Pets key throughout the data.",
    "expressions": [
      "count(.. | objects | (.Pets // []) | flatten[] | select(.==\"Dog\"))"
    ],
    "data": [
      {
        "input": [
          {
            "Data": {
              "IsInUS": 1,
              "Pets": [
                [
                  "Dog",
                  "Cat",
                  "Bird"
                ]
              ],
              "Favorite Pet": "Dog"
            },
            "UniqueID": "1234"
          },
          {
            "Data": {
              "IsInUS": 1,
              "Pets": [
                [
                  "Dog",
                  "Cat",
                  "Bird"
                ]
              ],
              "Favorite Pet": "Cat"
            },
            "UniqueID": "234"
          }
        ],
        "output": 2
      }
    ],
    "identifier": 50940865
  },
  {
    "context": [
      "Is there a way before doing the delete of `.scopedName`, to use it&#39;s value to set `.name`?",
      "Transforming your input to your output is as simple as:\r\n\r\n    jq &#39;{\"name\": .transitive.scopedName}&#39;",
      "and of course you could just reorder things to set `name` *before* deleting `transitive`:\r\n\r\n    jq '.name=.transitive.scopedName | del(.transitive)'",
      "if you **really** want to use `del()` first, you can save content in a variable and use it later:\r\n\r\n    jq '\n      .transitive as $transitive |\n      del(.transitive) |\n      .name=$transitive.scopedName\n    '"
    ],
    "utterance": "Set the top-level name field to the value of transitive.scopedName and remove all other fields.",
    "expressions": [
      "{\"name\": .transitive.scopedName}",
      ".name=.transitive.scopedName | del(.transitive)",
      ".transitive as $transitive | del(.transitive) | .name=$transitive.scopedName"
    ],
    "data": [
      {
        "input": {
          "name": "navigation",
          "transitive": {
            "name": "navigation",
            "scope": "bs",
            "scopedName": "@bs/navigation"
          }
        },
        "output": {
          "name": "@bs/navigation"
        }
      }
    ],
    "identifier": 50937290
  },
  {
    "context": [
      "I am trying to implement this regex from a regex builder into a test function, but am unfamiliar with how to escape some of the characters for the syntax to work. I am using the regex in a `test(\" \")` function",
      "map({Row: .[] })\n|\tmap(select(.Row.payload.hours | test(\".+?sunday.+?\"[0-9]:\\d+.+\")?))",
      "You just have to encode the regex string as a JSON string. This is easy enough to do if you know something about JSON strings, but you could let jq do the walking, e.g. using\n\n    jq -R . regex.txt\n\nassuming your regex is in the file regex.txt"
    ],
    "utterance": "Test if the 'hours' field contains a substring matching the regex .+?sunday.+?\"[0-9]:\\d+.+",
    "expressions": [
      "map({Row: .[]}) | map(select(.Row.payload.hours | test(\".+?sunday.+?\\\"[0-9]:\\\\d+.+\")))"
    ],
    "identifier": 50942755
  },
  {
    "context": [
      "How do I write a simple line of code in a script to change the name fields to be lowercase values and to filter out objects where id and releaseDate are null?",
      "the following will select the objects for which both .id and .releaseDate are non-null, and convert the ASCII alphabetic characters in the .name value to lowercase:",
      "map(select(.id and .releaseDate) | .name |= ascii_downcase)"
    ],
    "utterance": "Filter objects where both id and releaseDate are not null and convert the name field to lowercase.",
    "expressions": [
      "map(select(.id and .releaseDate) | .name |= ascii_downcase)"
    ],
    "data": [
      {
        "input": [
          {
            "self": "link",
            "id": "18900",
            "name": "AUDI",
            "releaseDate": "2015-12-11"
          },
          {
            "self": "link",
            "id": "18900",
            "name": "FORD",
            "releaseDate": "2015-12-11"
          }
        ],
        "output": [
          {
            "self": "link",
            "id": "18900",
            "name": "audi",
            "releaseDate": "2015-12-11"
          },
          {
            "self": "link",
            "id": "18900",
            "name": "ford",
            "releaseDate": "2015-12-11"
          }
        ]
      }
    ],
    "identifier": 50941820
  },
  {
    "context": [
      "What I am trying to accomplish is to group IDs with the same exception. Something such as:\n\n    [{\n    \"Exception\": \"ReadTimeout\",\n     [{\n       \"ID\": 2492,\n       \"ID\": 3060\n     }]\n    },\n    {\n    \"Exception\": \"Deadline Exceeded\",\n     [{\n       \"ID\": 1082\n     }]\n    }]",
      "The illustrative output is invalid as JSON and has objects with repeated keys, which is probably not what you actually want, but the following jq program will produce output that is in accordance with the general problem description.",
      "Since you do not seem to have specified the precise grouping criterion, I have taken the error message text after the last \":\" as the grouping criterion.",
      "The first step gathers the .failed_projects together and applies to_entries so that we can readily access the ID and error message text:\n\n    [.[] | .failed_projects | to_entries[]]",
      "Next we extract the grouping criterion, and use it to form the groups:\n\n    | map(.value |= sub(\"^.*: *\";\"\"))\n    | group_by(.value)",
      "Finally, we transform the groups into JSON objects of the form:\n{GROUP: ARRAY_OF_IDs}:\n\n    | map( .[0].value as $key\n           | [.[] | .key] as $value\n           | {($key): $value} )",
      "Putting the above fragments together in a file, program.jq, and using the invocation:\n\n    jq -f program.jq input.json\n\nyields the output shown below.",
      "[\n  {\n    \"Deadline Exceeded, trace\": [\n      \"1082\"\n    ]\n  },\n  {\n    \"TimeoutError)\": [\n      \"6728\",\n      \"6747\",\n      \"6939\",\n      \"5570\",\n      \"6103\",\n      \"6188\",\n      \"6695\",\n      \"6721\",\n      \"2492\",\n      \"6760\",\n      \"3060\",\n      \"6941\",\n      \"6942\",\n      \"6947\",\n      \"7787\"\n    ]\n  },\n  {\n    \"in `__raise_transport_error'\": [\n      \"1273\",\n      \"7201\"\n    ]\n  },\n  {\n    \"in `run_indexer!'\\\"\": [\n      \"7707\"\n    ]\n  }\n]"
    ],
    "utterance": "Group all failed project IDs together by their exception message, so that IDs with the same exception are collected in the same group.",
    "expressions": [
      "[.[] | .failed_projects | to_entries[]]\n| map(.value |= sub(\"^.*: *\"; \"\"))\n| group_by(.value)\n| map(.[0].value as $key | [.[] | .key] as $value | {($key): $value})"
    ],
    "data": [
      {
        "input": [
          {
            "LAST_JOB_POD": "gitlab-web-65-gwwwh",
            "STARTED_AT": "31-05-2018-18:18:48",
            "FINISHED": "false",
            "FIRST_INDEXED": "0",
            "LAST_INDEXED": "3143",
            "failed_projects": {
              "1082": "4:Deadline Exceeded, trace",
              "1273": "/opt/gitlab/embedded/lib/ruby/gems/2.3.0/gems/elasticsearch-transport-5.0.3/lib/elasticsearch/transport/transport/base.rb:201:in `__raise_transport_error'",
              "2492": "/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill': Net::ReadTimeout (Faraday::TimeoutError)",
              "3060": "/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill': Net::ReadTimeout (Faraday::TimeoutError)"
            }
          },
          {
            "LAST_JOB_POD": "gitlab-web-65-gwwwh",
            "STARTED_AT": "31-05-2018-18:18:48",
            "FINISHED": "false",
            "FIRST_INDEXED": "0",
            "LAST_INDEXED": "3143",
            "failed_projects": {
              "5570": "/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill': Net::ReadTimeout (Faraday::TimeoutError)",
              "6103": "/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill': Net::ReadTimeout (Faraday::TimeoutError)",
              "6188": "/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill': Net::ReadTimeout (Faraday::TimeoutError)",
              "6695": "/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill': Net::ReadTimeout (Faraday::TimeoutError)",
              "6721": "/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill': Net::ReadTimeout (Faraday::TimeoutError)",
              "6728": "/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill': Net::ReadTimeout (Faraday::TimeoutError)",
              "6747": "/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill': Net::ReadTimeout (Faraday::TimeoutError)"
            }
          },
          {
            "LAST_JOB_POD": "gitlab-web-65-gwwwh",
            "STARTED_AT": "31-05-2018-18:18:48",
            "FINISHED": "false",
            "FIRST_INDEXED": "0",
            "LAST_INDEXED": "3143",
            "failed_projects": {
              "6760": "/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill': Net::ReadTimeout (Faraday::TimeoutError)",
              "6939": "/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill': Net::ReadTimeout (Faraday::TimeoutError)",
              "6941": "/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill': Net::ReadTimeout (Faraday::TimeoutError)",
              "6942": "/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill': Net::ReadTimeout (Faraday::TimeoutError)",
              "6947": "/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill': Net::ReadTimeout (Faraday::TimeoutError)",
              "7201": "/opt/gitlab/embedded/lib/ruby/gems/2.3.0/gems/elasticsearch-transport-5.0.3/lib/elasticsearch/transport/transport/base.rb:201:in `__raise_transport_error'",
              "7707": ", trace - [\"/opt/gitlab/embedded/service/gitlab-rails/ee/lib/gitlab/elastic/indexer.rb:64:in `run_indexer!'\\\"",
              "7787": "/opt/gitlab/embedded/lib/ruby/2.3.0/net/protocol.rb:176:in `rbuf_fill': Net::ReadTimeout (Faraday::TimeoutError)"
            }
          }
        ],
        "output": [
          {
            "Deadline Exceeded, trace": [
              "1082"
            ]
          },
          {
            "TimeoutError)": [
              "6728",
              "6747",
              "6939",
              "5570",
              "6103",
              "6188",
              "6695",
              "6721",
              "2492",
              "6760",
              "3060",
              "6941",
              "6942",
              "6947",
              "7787"
            ]
          },
          {
            "in `__raise_transport_error'": [
              "1273",
              "7201"
            ]
          },
          {
            "in `run_indexer!'\\\"": [
              "7707"
            ]
          }
        ]
      }
    ],
    "identifier": 50678440
  },
  {
    "context": [
      "How can one parse the second set, namely the array data that comes after the data: tag in the second { } block.",
      "Thus if you only want the second object (converted to valid JSON), you could run:\r\n\r\n    (echo \"[\"; cat census.txt; echo \"]\") | hjson -j | jq '.[1]'"
    ],
    "utterance": "Extract the 'data' array from the second object in a file containing two top-level objects concatenated together.",
    "expressions": [
      "jq '.[1].data'"
    ],
    "data": [
      {
        "input": [
          {
            "dummy": "first object"
          },
          {
            "data": [
              {
                "foo": "bar"
              }
            ]
          }
        ],
        "output": [
          {
            "foo": "bar"
          }
        ]
      }
    ],
    "identifier": 50933870
  },
  {
    "context": [
      "I have a json output ... I'd like to have the output like this based on the description and subnet:",
      "THA4  \n0.0.0.0  \nALF5  \n1.2.3.4",
      "and want to have like this too:",
      "THA4,0.0.0.0  \nALF5,1.2.3.4",
      "To obtain the desired linear listing, just hoist the `[]`:",
      "jq -r '.data[] | (.description, .subnet)'",
      "One way to get CSV is to use `@csv`:",
      ".data[]\n| [.description, .subnet]\n| @csv",
      "If you don't want the individual values to be quoted:",
      ".data[] | \"\\(.description), \\(.subnet)\""
    ],
    "utterance": "Extract, for each item, the description and corresponding subnet as either separate lines or as comma-separated pairs.",
    "expressions": [
      ".data[] | (.description, .subnet)",
      ".data[] | [ .description, .subnet ] | @csv",
      ".data[] | \"\\(.description),\\(.subnet)\""
    ],
    "data": [
      {
        "input": {
          "code": 200,
          "success": true,
          "data": [
            {
              "id": "66",
              "subnet": "0.0.0.0",
              "mask": "",
              "sectionId": "1",
              "description": "THA4"
            },
            {
              "id": "72",
              "subnet": "1.2.3.4",
              "mask": "",
              "sectionId": "1",
              "description": "ALF5"
            }
          ]
        },
        "output": [
          "THA4",
          "0.0.0.0",
          "ALF5",
          "1.2.3.4"
        ]
      },
      {
        "input": {
          "code": 200,
          "success": true,
          "data": [
            {
              "id": "66",
              "subnet": "0.0.0.0",
              "mask": "",
              "sectionId": "1",
              "description": "THA4"
            },
            {
              "id": "72",
              "subnet": "1.2.3.4",
              "mask": "",
              "sectionId": "1",
              "description": "ALF5"
            }
          ]
        },
        "output": [
          "\"THA4\",\"0.0.0.0\"",
          "\"ALF5\",\"1.2.3.4\""
        ]
      },
      {
        "input": {
          "code": 200,
          "success": true,
          "data": [
            {
              "id": "66",
              "subnet": "0.0.0.0",
              "mask": "",
              "sectionId": "1",
              "description": "THA4"
            },
            {
              "id": "72",
              "subnet": "1.2.3.4",
              "mask": "",
              "sectionId": "1",
              "description": "ALF5"
            }
          ]
        },
        "output": [
          "THA4,0.0.0.0",
          "ALF5,1.2.3.4"
        ]
      }
    ],
    "identifier": 50939615
  },
  {
    "context": [
      "To convert an array as shown to the \".ini\" format could be accomplished by simply using this jq program:",
      "def kv: to_entries[] | \"\\(.key)=\\(.value)\";",
      ".[] | to_entries[] | \"[\\(.key)]\", (.value|kv)",
      "If you want to ensure that the program will also handle the case when there is no enclosing array, you could modify the first line in the main program above to test whether the input is an array, so you'd have:",
      "if type == \"array\" then .[] else . end | to_entries[] | \"[\\(.key)]\", (.value|kv)",
      "The driver program would however now be:",
      ".[] | [to_entries[] | \"[\\(.key)]\", (.value|kv)] | join(\"\\n\")",
      "Running jq with this program then yields one JSON string for each item in the array."
    ],
    "utterance": "Produce output where each object in an array becomes one string formatted with section headers and key-value pairs, resembling INI file format, such as '[connection]\\nid=br0\\n...' and '[ipv4]\\nmethod=manual\\n...'.",
    "expressions": [
      "def kv: to_entries[] | \"\\(.key)=\\(.value)\"; .[] | to_entries[] | \"[\\(.key)]\", (.value|kv)",
      "def kv: to_entries[] | \"\\(.key)=\\(.value)\"; if type == \"array\" then .[] else . end | to_entries[] | \"[\\(.key)]\", (.value|kv)",
      "def kv: to_entries[] | \"\\(.key)=\\(.value)\"; .[] | [to_entries[] | \"[\\(.key)]\", (.value|kv)] | join(\"\\n\")"
    ],
    "data": [
      {
        "input": [
          {
            "connection": {
              "id": "br0",
              "uuid": "ab1dd903-4786-4c7e-a4b4-3339b144d6c7",
              "stable-id": "",
              "type": "bridge",
              "interface-name": "br0",
              "autoconnect": "no",
              "autoconnect-priority": "0",
              "autoconnect-retries": "-1",
              "auth-retries": "-1",
              "timestamp": "44444",
              "read-only": "no",
              "permissions": "",
              "zone": "WAN",
              "master": "",
              "slave-type": "",
              "autoconnect-slaves": "1",
              "secondaries": "",
              "gateway-ping-timeout": "0",
              "metered": "unknown",
              "lldp": "default"
            },
            "ipv4": {
              "method": "manual",
              "dns": "192.168.1.1,192.168.2.1",
              "dns-search": "",
              "dns-options": " ",
              "dns-priority": "0",
              "addresses": "192.168.1.3/24",
              "gateway": "",
              "routes": "192.168.10.0/24 192.168.1.1",
              "route-metric": "-1",
              "route-table": "0",
              "ignore-auto-routes": "no",
              "ignore-auto-dns": "no",
              "dhcp-client-id": "",
              "dhcp-timeout": "0",
              "dhcp-send-hostname": "yes",
              "dhcp-hostname": "",
              "dhcp-fqdn": "",
              "never-default": "no",
              "may-fail": "yes",
              "dad-timeout": "-1"
            }
          }
        ],
        "output": "[connection]\nid=br0\nuuid=ab1dd903-4786-4c7e-a4b4-3339b144d6c7\nstable-id=\ntype=bridge\ninterface-name=br0\nautoconnect=no\nautoconnect-priority=0\nautoconnect-retries=-1\nauth-retries=-1\ntimestamp=44444\nread-only=no\npermissions=\nzone=WAN\nmaster=\nslave-type=\nautoconnect-slaves=1\nsecondaries=\ngateway-ping-timeout=0\nmetered=unknown\nlldp=default\n[ipv4]\nmethod=manual\ndns=192.168.1.1,192.168.2.1\ndns-search=\ndns-options= \ndns-priority=0\naddresses=192.168.1.3/24\ngateway=\nroutes=192.168.10.0/24 192.168.1.1\nroute-metric=-1\nroute-table=0\nignore-auto-routes=no\nignore-auto-dns=no\ndhcp-client-id=\ndhcp-timeout=0\ndhcp-send-hostname=yes\ndhcp-hostname=\ndhcp-fqdn=\nnever-default=no\nmay-fail=yes\ndad-timeout=-1"
      }
    ],
    "identifier": 50902634
  }
]