[
  {
    "context": [
      "How to use JQ to select filename ?",
      "If you want both filenames:\r\n\r\n    .[].fileName"
    ],
    "utterance": "Select all fileName values from each object in the array.",
    "expressions": [
      ".[].fileName"
    ],
    "data": [
      {
        "input": [
          {
            "fileName": "FOO",
            "md5": "blablabla"
          },
          {
            "fileName": "BAR",
            "md5": "alaldlafj"
          }
        ],
        "output": [
          "FOO",
          "BAR"
        ]
      }
    ],
    "identifier": 52488495
  },
  {
    "context": [
      "How do I use it to access fields of a json object that happen to be numeric strings?",
      "For example, the following fails for me with an error:",
      "echo '{\"20\":\"twenty\"}' | jq .[\"20\"]",
      "Use single quotes to protect that entire string from modification by the shell:",
      "$ echo '{\"20\":\"twenty\"}' | jq '.[\"20\"]'",
      "\"twenty\"",
      "jq: error (at <stdin>:1): Cannot index object with number"
    ],
    "utterance": "Retrieve the value of the field with the key \"20\" (a numeric string) from the input where the field's value is \"twenty\".",
    "expressions": [
      ".[\"20\"]"
    ],
    "data": [
      {
        "input": {
          "20": "twenty"
        },
        "output": "twenty"
      }
    ],
    "identifier": 52460453
  },
  {
    "context": [
      "I want to compare if they are the same object.",
      "They are the same, but an md5sum will see them as different.",
      "I would like to know if it's possible to use jq on the fly to compare variables.",
      "I've been trying to change --argfile a a.json for --arg a $a (being $a a json string) with no luck.",
      "It would probably be simplest to use the `--argjson` command-line option, e.g.",
      "jq -n --argjson a \"$a\" --argjson b \"$b\" '$a == $b'"
    ],
    "utterance": "Test whether two objects represented as variables contain the same data regardless of key order.",
    "expressions": [
      "$a == $b"
    ],
    "data": [
      {
        "input": [
          {
            "type": {
              "S": "equal"
            },
            "preFilter": {
              "BOOL": true
            }
          },
          {
            "preFilter": {
              "BOOL": true
            },
            "type": {
              "S": "equal"
            }
          }
        ],
        "output": true
      }
    ],
    "identifier": 52488950
  },
  {
    "context": [
      "I have to query a jason file to retrieve the value of service_name, then take the value, remove the double quotes, convert spaces to dashes, and then uppercase to lower case.",
      "You can do all of this in `jq` itself:",
      "$ jq -r '.client.service_name | ascii_downcase | split(\" \") | join(\"-\")' <<EOF ... two-men-and-a-truck"
    ],
    "utterance": "Retrieve the value of client.service_name, convert it to lowercase, replace spaces with dashes, and remove double quotes.",
    "expressions": [
      ".client.service_name | ascii_downcase | split(\" \") | join(\"-\")"
    ],
    "data": [
      {
        "input": {
          "port": 5000,
          "machine": "102",
          "ip": "xxx.xxx.xxx.xxx",
          "drum_id": "1305145216186552",
          "client": {
            "service_name": "Two Men And A Truck",
            "vendor": "default"
          }
        },
        "output": "two-men-and-a-truck"
      }
    ],
    "identifier": 52506148
  },
  {
    "context": [
      "Another way to skip the header row is to use `inputs` without the `-n` command-line option, as follows.  Using `inputs` is also much more efficient than using the `-s` command-line option.",
      "< source.csv sed 's/[\\\"<>]//g' |\njq -cR 'inputs \n      | split(\",\")\n      | {\"phone_number\":.[0],\"opt_in\":\"yes\"}'"
    ],
    "utterance": "Skip the first header row and output objects with phone_number and opt_in fields for each remaining line, extracting the first column as phone_number and setting opt_in to yes.",
    "expressions": [
      "inputs | split(\",\") | {\"phone_number\": .[0], \"opt_in\": \"yes\"}"
    ],
    "data": [
      {
        "input": "\"1. ID\",\"2. Height\",\"3. Gender\",\"4. Age\"\n\"<1111111111>\",\"5ft. 10.0in.\",\"M\",\" 15.0\"\n\"<2222222222>\",\"6ft. 0in.\",\"M\",\" 22.0\"",
        "output": [
          {
            "phone_number": "1111111111",
            "opt_in": "yes"
          },
          {
            "phone_number": "2222222222",
            "opt_in": "yes"
          }
        ]
      }
    ],
    "identifier": 52485114
  },
  {
    "context": [
      ".value.security |= [ { $authorizer_name : \"stuff\" }]",
      "The solution is to surround the argument with `()` ie. `.value.security |= [ { ($authorizer_name) : \"stuff\" }]`",
      "the problem goes away if you enclose `$authorizer_name` in parentheses:",
      "{ ($authorizer_name) : \"stuff\" }",
      "when using the object construction syntax as here, each expression specifying a key name must be enclosed in parentheses unless it is a JSON string."
    ],
    "utterance": "Replace the 'security' array at each path method with a new array containing an object whose key is the value of the authorizer_name variable and value is 'stuff'.",
    "expressions": [
      ".paths |= with_entries(.value |= with_entries(.value.security |= [ { ($authorizer_name): \"stuff\" } ] ))"
    ],
    "data": [
      {
        "input": {
          "swagger": "2.0",
          "paths": {
            "integrations/systems/{system_id}/configurations": {
              "get": {
                "security": [
                  "https://api.com/internal-api"
                ]
              }
            }
          }
        },
        "output": {
          "swagger": "2.0",
          "paths": {
            "integrations/systems/{system_id}/configurations": {
              "get": {
                "security": [
                  {
                    "cognito_user_pool": "stuff"
                  }
                ]
              }
            }
          }
        }
      }
    ],
    "identifier": 52452705
  },
  {
    "context": [
      "I would like to get a sample inside point of the polygon.",
      "it suffices to sum all longitudes and all latitudes together then divide it by the number of points.",
      "compute the sum of the longitudes and sum of the latitudes as well, and reinject the barycenter in `properties` field in another geoJSON file?",
      ".features[].geometry.coordinates[0]\n| [ [.[][0]], [.[][1]] ]\n| map(add/length)",
      ".features[] |= (\n    (.geometry.coordinates[0] | length as $len | reduce .[] as [$x, $y] ([0,0];\n        [.[0] + $x, .[1] + $y]\n    ) | map(. / $len)) as $barrycenter |\n    .properties.barycenter = $barrycenter\n)"
    ],
    "utterance": "For each feature, compute the average of the longitudes and the average of the latitudes of the polygon vertices, and add this point as the 'barycenter' property in properties.",
    "expressions": [
      ".features[] |= (\n    (.geometry.coordinates[0] | length as $len | reduce .[] as [$x, $y] ([0,0];\n        [.[0] + $x, .[1] + $y]\n    ) | map(. / $len)) as $barrycenter |\n    .properties.barycenter = $barrycenter\n)"
    ],
    "data": [
      {
        "input": {
          "type": "FeatureCollection",
          "features": [
            {
              "type": "Feature",
              "geometry": {
                "type": "Polygon",
                "coordinates": [
                  [
                    [
                      2.41101,
                      48.72605
                    ],
                    [
                      2.41554,
                      48.72656
                    ],
                    [
                      2.41718,
                      48.72791
                    ]
                  ]
                ]
              },
              "properties": {
                "code": "94001",
                "nom": "Ablon-sur-Seine"
              }
            }
          ]
        },
        "output": {
          "type": "FeatureCollection",
          "features": [
            {
              "type": "Feature",
              "geometry": {
                "type": "Polygon",
                "coordinates": [
                  [
                    [
                      2.41101,
                      48.72605
                    ],
                    [
                      2.41554,
                      48.72656
                    ],
                    [
                      2.41718,
                      48.72791
                    ]
                  ]
                ]
              },
              "properties": {
                "code": "94001",
                "nom": "Ablon-sur-Seine",
                "barycenter": [
                  2.4145766666666666,
                  48.72684
                ]
              }
            }
          ]
        }
      }
    ],
    "identifier": 52467305
  },
  {
    "context": [
      "In the following, I am trying to delete one of the two objects in the \"bar\" array, the one where \"v\" == 2:",
      "Is there a way to delete a sub-object to keep the enclosing object:",
      "Use the `del` operator to delete the node you want:",
      ".bar |= map(select(.v ==2 | not))",
      "Or simply:",
      ".bar |= map(select(.v != 2))"
    ],
    "utterance": "Remove the element with v equal to 2 from the bar array, keeping the original object's structure.",
    "expressions": [
      "del(.bar[] | select(.v==2))",
      ".bar |= map(select(.v != 2))",
      ".bar |= map(select(.v ==2 | not))"
    ],
    "data": [
      {
        "input": {
          "foo": {},
          "bar": [
            {
              "v": 2
            },
            {
              "v": 1
            }
          ]
        },
        "output": {
          "foo": {},
          "bar": [
            {
              "v": 1
            }
          ]
        }
      }
    ],
    "identifier": 52512687
  },
  {
    "context": [
      "Suppose I have the following json in the file ver.json:\r\n\r\n    [{\"id\":\"123\",\"product\":13038},{\"id\":\"456\",\"product\":1212}]",
      "This would be the correct answer:\r\n\r\n    123,13038\r\n    456,1212",
      "Instead pipe `.[]` once to two different parentheticals:",
      "    ~$ jq -r '.[] | (.id | tostring) + \",\" + (.product | tostring)' ver.json",
      "Or more compactly:",
      "    $ jq -r '.[] | \"\\(.id),\\(.product)\"'",
      "It may also be worth noting that `@csv` retains the types:\r\n\r\n    $ jq -r '.[] | [.id,.product] | @csv'"
    ],
    "utterance": "Produce output lines combining id and product fields from each object in the array, separated by a comma, as in '123,13038' and '456,1212'.",
    "expressions": [
      ".[] | (.id | tostring) + \",\" + (.product | tostring)",
      ".[] | \"\\(.id),\\(.product)\"",
      ".[] | [.id,.product] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "id": "123",
            "product": 13038
          },
          {
            "id": "456",
            "product": 1212
          }
        ],
        "output": [
          "123,13038",
          "456,1212"
        ]
      }
    ],
    "identifier": 52507077
  },
  {
    "context": [
      "I need to count number of objects in each group with JQ, but only for N most recent objects.",
      "Sample input, for N=3:",
      "{ \"modified\":\"Mon Sep 25 14:20:00 +0000 2018\",\"object_id\":1,\"group_id\":\"C\" }",
      "{ \"modified\":\"Mon Sep 25 14:23:00 +0000 2018\",\"object_id\":2,\"group_id\":\"A\" }",
      "{ \"modified\":\"Mon Sep 25 14:21:00 +0000 2018\",\"object_id\":3,\"group_id\":\"B\" }",
      "{ \"modified\":\"Mon Sep 25 14:22:00 +0000 2018\",\"object_id\":4,\"group_id\":\"A\" }",
      "Expected output:",
      "{ \"A\",2 }",
      "{ \"B\",1 }",
      "<file jq -s '\n   [ .[] | \n     (.modified |= (strptime(\"%a %b %d %H:%M:%S +0000 %Y\") | mktime)) \n   ] | \n   sort_by(.modified) |              # sort using converted time\n   .[-3:] |                          # take the last 3\n   group_by(.class_id) |             # group ids together\n   .[] |                             \n   {(.[0].class_id): length}'        # create the object using the id name and table length",
      "maxn(inputs; .modified | strptime(\"%a %b %d %H:%M:%S +0000 %Y\") | mktime; 3)\n| group_by(.class_id)[]\n| {(.[0].class_id): length}"
    ],
    "utterance": "Count number of objects for each group_id among the 3 most recent objects, grouping by group_id.",
    "expressions": [
      "[ .[] | (.modified |= (strptime(\"%a %b %d %H:%M:%S +0000 %Y\") | mktime)) ] | sort_by(.modified) | .[-3:] | group_by(.group_id) | .[] | {(.[0].group_id): length}",
      "def maxn(stream; filter; n): reduce stream as $x ([]; . + [$x] | sort_by(filter) | .[-n:]); maxn(inputs; .modified | strptime(\"%a %b %d %H:%M:%S +0000 %Y\") | mktime; 3) | group_by(.group_id)[] | {(.[0].group_id): length}"
    ],
    "data": [
      {
        "input": [
          {
            "modified": "Mon Sep 25 14:20:00 +0000 2018",
            "object_id": 1,
            "group_id": "C"
          },
          {
            "modified": "Mon Sep 25 14:23:00 +0000 2018",
            "object_id": 2,
            "group_id": "A"
          },
          {
            "modified": "Mon Sep 25 14:21:00 +0000 2018",
            "object_id": 3,
            "group_id": "B"
          },
          {
            "modified": "Mon Sep 25 14:22:00 +0000 2018",
            "object_id": 4,
            "group_id": "A"
          }
        ],
        "output": [
          {
            "A": 2
          },
          {
            "B": 1
          }
        ]
      }
    ],
    "identifier": 52497587
  },
  {
    "context": [
      "but now I need to **move every folder to it's `parent`'s `children` array**",
      "reduce pathnames as $pn ({};\n  getpath($pn.path + [\"children\"]) as $children\n  | setpath($pn.path + [\"children\"]; $children + [$pn.file]) )"
    ],
    "utterance": "Nest each folder under its parent's children array so that the directory tree is hierarchical, not flat.",
    "expressions": [
      "def parsePathname: split(\"\\\\\") | {path: .[0:length-1], file: .[-1]};\n\ndef pathnames:\n  foreach inputs as $x (null;\n    if . == null\n    then if ($x|length) == 0 then 0 else . end\n    else .+1\n    end;\n    select(. and . > 0)|$x)\n    | parsePathname ;\n\nreduce pathnames as $pn ({};\n  getpath($pn.path + [\"children\"]) as $children\n  | setpath($pn.path + [\"children\"]; $children + [$pn.file]) )"
    ],
    "identifier": 52523718
  },
  {
    "context": [
      "How can I call a function by name specified as command-line argument?",
      "Is it possible to also specify a file to include with a command-line argument to JQ?",
      "Neither jq function names nor module names can be specified as jq variables, and so to achieve what you seem to want, you would have to resort to shell string-interpolation, or lookup expressions.",
      "jq supports array-based path expressions, and so certain kinds of lookups can be supported using jq variables."
    ],
    "utterance": "Invoke a function whose name and module are specified as command-line arguments.",
    "expressions": [],
    "data": [],
    "identifier": 52524449
  },
  {
    "context": [
      "I am trying to match for `\"name\" : \"redirect\"` inside each `behaviors` array and if it matches then I need the entire block including the \"criteria\" section, as you can see its under same block `{}`",
      "You can try this jq command:\n\n     <file jq 'select(.[].behaviors[].name==\"redirect\")'",
      ".[]\n| select(any(.behaviors[]; .name == \"redirect\"))"
    ],
    "utterance": "Return each top-level object where any item in the behaviors array has a name equal to 'redirect'.",
    "expressions": [
      ".[] | select(any(.behaviors[]; .name == \"redirect\"))",
      ".[] | first(select(.behaviors[].name == \"redirect\"))"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Redirect to Website 1",
            "behaviors": [
              {
                "name": "redirect",
                "options": {
                  "mobileDefaultChoice": "DEFAULT",
                  "destinationProtocol": "HTTPS",
                  "destinationHostname": "SAME_AS_REQUEST",
                  "responseCode": 302
                }
              }
            ],
            "criteria": [
              {
                "name": "requestProtocol",
                "options": {
                  "value": "HTTP"
                }
              }
            ],
            "criteriaMustSatisfy": "all"
          },
          {
            "name": "Redirect to Website 2",
            "behaviors": [
              {
                "name": "redirect",
                "options": {
                  "mobileDefaultChoice": "DEFAULT",
                  "destinationProtocol": "HTTPS",
                  "destinationHostname": "SAME_AS_REQUEST",
                  "responseCode": 301
                }
              }
            ],
            "criteria": [
              {
                "name": "contentType",
                "options": {
                  "matchOperator": "IS_ONE_OF",
                  "values": [
                    "text/html*",
                    "text/css*",
                    "application/x-javascript*"
                  ]
                }
              }
            ],
            "criteriaMustSatisfy": "all"
          }
        ],
        "output": [
          {
            "name": "Redirect to Website 1",
            "behaviors": [
              {
                "name": "redirect",
                "options": {
                  "mobileDefaultChoice": "DEFAULT",
                  "destinationProtocol": "HTTPS",
                  "destinationHostname": "SAME_AS_REQUEST",
                  "responseCode": 302
                }
              }
            ],
            "criteria": [
              {
                "name": "requestProtocol",
                "options": {
                  "value": "HTTP"
                }
              }
            ],
            "criteriaMustSatisfy": "all"
          },
          {
            "name": "Redirect to Website 2",
            "behaviors": [
              {
                "name": "redirect",
                "options": {
                  "mobileDefaultChoice": "DEFAULT",
                  "destinationProtocol": "HTTPS",
                  "destinationHostname": "SAME_AS_REQUEST",
                  "responseCode": 301
                }
              }
            ],
            "criteria": [
              {
                "name": "contentType",
                "options": {
                  "matchOperator": "IS_ONE_OF",
                  "values": [
                    "text/html*",
                    "text/css*",
                    "application/x-javascript*"
                  ]
                }
              }
            ],
            "criteriaMustSatisfy": "all"
          }
        ]
      }
    ],
    "identifier": 52515945
  },
  {
    "context": [
      "json='[{\"id\":1,\"name\":\"jdjson\"},{\"id\":2,\"name\":\"imagetookit\"}]'",
      "detail=$(echo \"$json\" | jq '.[]|select(.id==2)')",
      "{\n   \"id\": 2,\n   \"name\": \"imagetookit\"\n}"
    ],
    "utterance": "Extract the object with id equal to 2 from the provided array.",
    "expressions": [
      ".[] | select(.id==2)"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "name": "jdjson"
          },
          {
            "id": 2,
            "name": "imagetookit"
          }
        ],
        "output": {
          "id": 2,
          "name": "imagetookit"
        }
      }
    ],
    "identifier": 52537826
  },
  {
    "context": [
      "Your JSON object has a top-level field \"stream\" You need to access \"stream\" to access the other sub-properties, e.g. `channel`:",
      "jq '.stream.channel.status' parse.json",
      "You can also do `cat parse.json | jq '.stream.channel.status'`.",
      "To deal with the invalid JSON, you could use a JSON rectifier such as `hjson`; to avoid any hassles associated with identifying the relevant paths, you could use `..|objects`.  Thus for example:",
      "$ hjson -j parse.json | jq '..|objects|select(.status) | .status, ._id, .name'"
    ],
    "utterance": "Extract the status, _id, and name fields from the channel object nested inside stream.",
    "expressions": [
      ".stream.channel | {status, _id, name}",
      ".stream.channel.status, .stream.channel._id, .stream.channel.name",
      "..|objects|select(.status) | .status, ._id, .name"
    ],
    "data": [
      {
        "input": {
          "stream": {
            "_id": 65675798730520654496,
            "broadcast_platform": "live",
            "community_id": "",
            "community_ids": [],
            "average_fps": 60.0247524752,
            "delay": 0,
            "created_at": "2018-09-26T07:25:38Z",
            "is_playlist": false,
            "stream_type": "live",
            "preview": {
              "small": "https://static-cdn.jtvnw.net/previews-ttv/live_user_versuta-80x4512wdfqf.jpg"
            },
            "channel": {
              "mature": true,
              "status": "status",
              "broadcaster_language": "ru",
              "broadcaster_software": "",
              "_id": 218025408945123423423445,
              "name": "djvbsdhvsdvasdv",
              "created_at": "2011-04-17T17:31:36.091604Z",
              "updated_at": "2018-09-26T09:49:04.434245Z",
              "partner": true,
              "video_banner": null,
              "profile_banner": "https://static-cdn.jtvnw.net/jtv_user_pictures/25c2bec3-95b8-4347-aba0-128b3b913b0d-profile_banner-480.png",
              "profile_banner_background_color": "",
              "views": 103911737,
              "followers": 446198,
              "broadcaster_type": "",
              "description": "",
              "private_video": false,
              "privacy_options_enabled": false
            }
          }
        },
        "output": {
          "status": "status",
          "_id": 218025408945123423423445,
          "name": "djvbsdhvsdvasdv"
        }
      }
    ],
    "identifier": 52519743
  },
  {
    "context": [
      "It seems to me after some time trying to determine why it wasn't working that jq fails silently when working with a file path string that's length 28, or simply stops working if the file path string is length 29 or more.",
      "E.g. on `cmd` ... C:\\jq>jq . 123456789012345678901234567 displays prettified content of the file; ... C:\\jq>jq . 1234567890123456789012345678 displays nothing; ... C:\\jq>jq . 12345678901234567890123456789 causes a \"jq-win64.exe has stopped working\" window.",
      "There was a Windows-specific bug in jq 1.5 (see e.g. https://github.com/stedolan/jq/issues/1094).  It was fixed shortly after the release of jq 1.5."
    ],
    "utterance": "Prettify the contents of a file given by a file path whose length is 29 or more characters on Windows 7 using jq.",
    "expressions": [
      "jq . long_file_path.json"
    ],
    "identifier": 52546719
  },
  {
    "context": [
      "My objective is get two numbers - the sum of all values contained in `num_bikes_available` and `num_ebikes_available` with one jq query.",
      "the filter:\n\n    .data.stations\n    | { bikes: map(.num_bikes_available) | add,\n        ebikes: map(.num_ebikes_available) | add }\n\nproduces:\n\n    {\n      \"bikes\": 22,\n      \"ebikes\": 0\n    }",
      "A more efficient solution would use `sigma`, e.g. as follows:\n\n    def sigma(s): reduce s as $x (0; .+$x);\n\n    .data.stations\n    | [sigma(.[] | .num_bikes_available),\n       sigma(.[] | .num_ebikes_available)]"
    ],
    "utterance": "Calculate the sum of all values in both the num_bikes_available and num_ebikes_available fields for all stations.",
    "expressions": [
      ".data.stations | { bikes: map(.num_bikes_available) | add, ebikes: map(.num_ebikes_available) | add }",
      "def sigma(s): reduce s as $x (0; .+$x); .data.stations | [sigma(.[] | .num_bikes_available), sigma(.[] | .num_ebikes_available)]"
    ],
    "data": [
      {
        "input": {
          "last_updated": 1537986541,
          "ttl": 10,
          "data": {
            "stations": [
              {
                "station_id": "304",
                "num_bikes_available": 22,
                "num_ebikes_available": 0,
                "num_bikes_disabled": 4,
                "num_docks_available": 7,
                "num_docks_disabled": 0,
                "is_installed": 1,
                "is_renting": 1,
                "is_returning": 0,
                "last_reported": 1537986269,
                "eightd_has_available_keys": true,
                "eightd_active_station_services": [
                  {
                    "id": "a58d9e34-2f28-40eb-b4a6-c8c01375657a"
                  }
                ]
              },
              {
                "station_id": "359",
                "num_bikes_available": 0,
                "num_ebikes_available": 0,
                "num_bikes_disabled": 2,
                "num_docks_available": 50,
                "num_docks_disabled": 1,
                "is_installed": 1,
                "is_renting": 1,
                "is_returning": 0,
                "last_reported": 1537986120,
                "eightd_has_available_keys": false,
                "eightd_active_station_services": [
                  {
                    "id": "2e104e31-606a-44af-8b25-ceaffc338489"
                  }
                ]
              }
            ]
          }
        },
        "output": {
          "bikes": 22,
          "ebikes": 0
        }
      }
    ],
    "identifier": 52524416
  },
  {
    "context": [
      "What I'd like it to get output that combines those objects. So something like : \n\n{\n  \"rfcomm\": \"\",\n  \"scsi_transport_iscsi\": \"\",\n  \"xt_conntrack\": \"nouveau,i915\"\n}",
      "[.[] | { (.module) : (.deps | join(\",\")) }] | add",
      "reduce .[] as $elem ({}; . + { ($elem.module): $elem.deps | join(\",\") })"
    ],
    "utterance": "Combine an array of objects into a single object mapping the module name to a comma-separated string of its deps.",
    "expressions": [
      "[.[] | { (.module) : (.deps | join(\",\")) }] | add",
      "reduce .[] as $elem ({}; . + { ($elem.module): $elem.deps | join(\",\") })"
    ],
    "data": [
      {
        "input": [
          {
            "size": "77824",
            "module": "rfcomm",
            "depcount": "4",
            "deps": []
          },
          {
            "size": "98304",
            "module": "scsi_transport_iscsi",
            "depcount": "4",
            "deps": []
          },
          {
            "size": "16384",
            "module": "xt_conntrack",
            "depcount": "1",
            "deps": [
              "nouveau",
              "i915"
            ]
          }
        ],
        "output": {
          "rfcomm": "",
          "scsi_transport_iscsi": "",
          "xt_conntrack": "nouveau,i915"
        }
      }
    ],
    "identifier": 52547428
  },
  {
    "context": [
      "I want to select elements >= 3 in an array like `[2, 4, 3]` with `jq`, how do I do it?",
      "If you want to retain the array structure, you could use `map(select(_))`, e.g.",
      "jq -n '[2, 4, 3] | map(select(. >= 3))'",
      "If you just want the values, you could consider:",
      "jq '.[] | select(. >= 3)' <<< '[2, 4, 3]'"
    ],
    "utterance": "Select all elements greater than or equal to 3 from the array [2, 4, 3].",
    "expressions": [
      "[2, 4, 3] | map(select(. >= 3))",
      ".[] | select(. >= 3)"
    ],
    "data": [
      {
        "input": [
          2,
          4,
          3
        ],
        "output": [
          4,
          3
        ]
      }
    ],
    "identifier": 52562979
  },
  {
    "context": [
      "If possible with JQ, I'd like to combine only the \"messages\" into a single JSON file while keeping them in the existing order.",
      "jq -n \"[inputs | .messages] | add\" *.json"
    ],
    "utterance": "Combine the 'messages' arrays from multiple files into a single array while keeping their original order.",
    "expressions": [
      "jq -n \"[inputs | .messages] | add\" *.json"
    ],
    "data": [
      {
        "input": [
          {
            "participants": [
              {
                "name": "Participant One"
              },
              {
                "name": "Participant Two"
              }
            ],
            "messages": [
              {
                "sender_name": "Participant One",
                "timestamp_ms": 99999999999,
                "content": "message content",
                "type": "Generic"
              },
              {
                "sender_name": "Participant Two",
                "timestamp_ms": 9999999999,
                "content": "message content",
                "type": "Generic"
              }
            ],
            "title": "chat title",
            "is_still_participant": true,
            "thread_type": "Regular",
            "thread_path": "thread path"
          },
          {
            "participants": [
              {
                "name": "Participant Three"
              },
              {
                "name": "Participant Two"
              }
            ],
            "messages": [
              {
                "sender_name": "Participant Three",
                "timestamp_ms": 9999999999,
                "content": "message content",
                "type": "Generic"
              },
              {
                "sender_name": "Participant Two",
                "timestamp_ms": 9999999999,
                "content": "message content",
                "type": "Generic"
              }
            ],
            "title": "chat title",
            "is_still_participant": true,
            "thread_type": "Regular",
            "thread_path": "thread path"
          }
        ],
        "output": [
          {
            "sender_name": "Participant One",
            "timestamp_ms": 99999999999,
            "content": "message content",
            "type": "Generic"
          },
          {
            "sender_name": "Participant Two",
            "timestamp_ms": 9999999999,
            "content": "message content",
            "type": "Generic"
          },
          {
            "sender_name": "Participant Three",
            "timestamp_ms": 9999999999,
            "content": "message content",
            "type": "Generic"
          },
          {
            "sender_name": "Participant Two",
            "timestamp_ms": 9999999999,
            "content": "message content",
            "type": "Generic"
          }
        ]
      }
    ],
    "identifier": 52547351
  },
  {
    "context": [
      "It works fine when I group by top-level field; it doesn't when I need to group by a field deep in an hierarchy of objects:",
      "jq -s --arg group_by_field \"a.b.c\" '\n  group_by(.[$group_by_field])\n  | .[]\n  | [ (.[0][$group_by_field] ) ]'\n    jq_group_on_test.json",
      "To pass in a path as a parameter, you have to use the array-path notation (i.e., an array of strings and/or integers):",
      "jq -s --argjson group_by_field '[\"a\",\"b\",\"c\"]' '\n  group_by( getpath($group_by_field) )\n  | .[]\n  | [ .[0] | getpath($group_by_field)  ]\n' jq_group_on_test.json",
      "Note the use of the command-line option `--argjson`."
    ],
    "utterance": "Group objects by the value at the nested path a.b.c, with the field path provided as a command-line argument.",
    "expressions": [
      "jq -s --argjson group_by_field '[\"a\",\"b\",\"c\"]' '\n  group_by(getpath($group_by_field))\n  | .[]\n  | [.[0] | getpath($group_by_field)]\n'"
    ],
    "data": [
      {
        "input": [
          {
            "a": {
              "b": {
                "c": "EFG"
              }
            },
            "d": "HIJ"
          }
        ],
        "output": [
          [
            "EFG"
          ]
        ]
      }
    ],
    "identifier": 52557156
  },
  {
    "context": [
      "As for the immediate issue: `.key` works with `{ \"foo\": \"value\" }`, but `.100` doesn't work with `{ \"100\": \"value\" }`; the syntax you're relying is sugar, only available for a limited subset of keys. `.[\"100\"]` would work, but generating that by expanding shell variables into strings parsed as code is fragile ... To do things the Right Way, pass your variables out-of-band from your code, and use them for lookups in a manner that doesn't rely on what they contain.",
      "The `jq` equivalent to awk's `-v var=\"$value\"` is `--arg var \"$value\"`, used thusly:",
      "jq --arg pgid \"$pgid\" \\\n   --arg tpogo \"$tpogo\" \\\n   '.[$pgid].pogo = $tpogo'",
      "jq --arg pgid \"$pgid\" --arg tpogo \"$tpogo\" \\\n   '.[$pgid].pogo = $tpogo' <<<\"$json\"",
      "...emits as output:\n\n{\n  \"0000000\": {\n    \"pogo\": \"XXXXXXX\"\n  },\n  \"7000000\": {\n    \"pogo\": \"PPPVUYKJBOIHKNNLNM\"\n  }\n}"
    ],
    "utterance": "Update the value of the 'pogo' field for the object with key '0000000' to 'XXXXXXX'",
    "expressions": [
      ".[\"0000000\"].pogo = \"XXXXXXX\"",
      "jq --arg pgid \"$pgid\" --arg tpogo \"$tpogo\" '.[$pgid].pogo = $tpogo'"
    ],
    "data": [
      {
        "input": {
          "0000000": {
            "pogo": "AJHVUYKJBOIHKNNLNM"
          },
          "7000000": {
            "pogo": "PPPVUYKJBOIHKNNLNM"
          }
        },
        "output": {
          "0000000": {
            "pogo": "XXXXXXX"
          },
          "7000000": {
            "pogo": "PPPVUYKJBOIHKNNLNM"
          }
        }
      }
    ],
    "identifier": 52562653
  },
  {
    "context": [
      "I want to modify the value of all `x` keys in a json that looks like:",
      "I can't modify the value of `x` and obtain the full json as a result. All I managed to do is modify the value of `x` and obtain the last array as a result.",
      "To change all `x` values to `97`, you can try this jq command:",
      ".a.b.c |= [.[]|.[].x=97]",
      ".a.b.c |= map(.[].x=97)",
      "If you really do want to \"modify the value of all x keys\", then you could use `walk`:",
      "walk(if type == \"object\" and has(\"x\") then .x=97 else . end)"
    ],
    "utterance": "Change every key named x to 97 wherever it occurs and return the entire structure.",
    "expressions": [
      ".a.b.c |= [.[]|.[].x=97]",
      ".a.b.c |= map(.[].x=97)",
      "walk(if type == \"object\" and has(\"x\") then .x=97 else . end)"
    ],
    "data": [
      {
        "input": {
          "a": {
            "b": {
              "c": [
                {
                  "0": {
                    "x": 23,
                    "name": "AS"
                  }
                },
                {
                  "1": {
                    "x": 23,
                    "name": "AS"
                  }
                },
                {
                  "2": {
                    "x": 23,
                    "name": "Fe"
                  }
                },
                {
                  "3": {
                    "x": 23,
                    "name": "Pl"
                  }
                }
              ]
            }
          }
        },
        "output": {
          "a": {
            "b": {
              "c": [
                {
                  "0": {
                    "x": 97,
                    "name": "AS"
                  }
                },
                {
                  "1": {
                    "x": 97,
                    "name": "AS"
                  }
                },
                {
                  "2": {
                    "x": 97,
                    "name": "Fe"
                  }
                },
                {
                  "3": {
                    "x": 97,
                    "name": "Pl"
                  }
                }
              ]
            }
          }
        }
      }
    ],
    "identifier": 52588489
  },
  {
    "context": [
      "jq -cn --stream '\n  fromstream(1|truncate_stream(inputs | select(.[0][0] == \"userActivities\") | del(.[0][0])))\n  | select(.localDate[0:7] == \"2018-10\")\n' 2018-10-01T21_45_56Z_triplem-baas_data.json > October_2018_triplem_events.json",
      "fromstream(1|truncate_stream(inputs | select(.[0][0] == \"userActivities\") | del(.[0][0])))\n  | (.localDate|debug) as $debug\n  | select(.localDate[0:7] == \"2018-10\")"
    ],
    "utterance": "Extract all objects where the top-level key is 'userActivities' and the 'localDate' field starts with '2018-10'.",
    "expressions": [
      "fromstream(1|truncate_stream(inputs | select(.[0][0] == \"userActivities\") | del(.[0][0]))) | select(.localDate[0:7] == \"2018-10\")"
    ],
    "identifier": 52601262
  },
  {
    "identifier": 52621359
  },
  {
    "context": [
      "The `officers` field holds a string which is JSON too. I&#39;d like to reduce this to:\r\n\r\n    [\r\n      { \"id\":117739, \"name\":\"Alice\" },\r\n      { \"id\":117739, \"name\":\"Bob\" },\r\n      { \"id\":117740, \"name\":\"Charlie\" }\r\n    ]",
      "Well the data you're attempting to flatten is itself JSON so you have to parse it using `fromjson`. Once parsed, you could then generate the new objects.",
      "map({id} + (.officers | fromjson[]))"
    ],
    "utterance": "For each object, extract the id and produce a flat array containing an object for each officer with their name and the corresponding id.",
    "expressions": [
      "map({id} + (.officers | fromjson[]))"
    ],
    "data": [
      {
        "input": [
          {
            "id": 117739,
            "officers": "[{\"name\":\"Alice\"},{\"name\":\"Bob\"}]"
          },
          {
            "id": 117740,
            "officers": "[{\"name\":\"Charlie\"}]"
          }
        ],
        "output": [
          {
            "id": 117739,
            "name": "Alice"
          },
          {
            "id": 117739,
            "name": "Bob"
          },
          {
            "id": 117740,
            "name": "Charlie"
          }
        ]
      }
    ],
    "identifier": 52614115
  },
  {
    "context": [
      "However I would like to use a variable (from the environment in the future) replacing the index '1' in the command above but this produces an error.",
      "echo '[  { \"CT\" : \"OS1\"  , \"VERSION\" : \"3\" } , { \"CT\" : \"OS2\"  , \"VERSION\" : \"3\" } ]'  | jq --arg index 1 '.[$index]'",
      "jq: error (at <stdin>:1): Cannot index array with string \"1\"",
      "If you have jq 1.4 or older, you could use the [`tonumber`][1] function:",
      "jq --arg index 1 '.[$index | tonumber]'",
      "You can use `--argjson` option:",
      "jq --argjson index 1 '.[$index]'"
    ],
    "utterance": "Access the array element at a variable index, where the index value is supplied as an argument.",
    "expressions": [
      ".[$index | tonumber]",
      ".[$index]"
    ],
    "data": [
      {
        "input": [
          {
            "CT": "OS1",
            "VERSION": "3"
          },
          {
            "CT": "OS2",
            "VERSION": "3"
          }
        ],
        "output": {
          "CT": "OS2",
          "VERSION": "3"
        }
      }
    ],
    "identifier": 52609226
  },
  {
    "context": [
      "I need to update JSON data with the given key and value. I tried passing this as variables for both key and value.",
      "I have JSON data, in my Unix method, I get key and value as parameters. I need to update the JSON data for that key with the given value.",
      "$ jq --arg key 'somekey' --arg value 'somevalue' 'reduce (paths | select(.[-1] | tostring == $key)) as $i (. ; setpath($i; $value))' input.json"
    ],
    "utterance": "Update the property in an object matching a given key with a specified value, where both key and value are provided as variables.",
    "expressions": [
      "reduce (paths | select(.[-1] | tostring == $key)) as $i (. ; setpath($i; $value))"
    ],
    "identifier": 52632140
  },
  {
    "context": [
      "How can i combine the `service.name` values separated by comma so they print like below:\n    {\n      \"number\": 1,\n      \"service name\": \"FTP-Server, SSH-Server\"\n    }",
      "With your second JSON text, the following filter:\n\n    .group[].group[]\n    | { \"number\": .number, \"service name\": ([.service[].name]|join(\", \")) }\n\nproduces the output that you've indicated you expected (including the space after the comma):\n\n    {\n      \"number\": 1,\n      \"service name\": \"FTP-Server, SSH-Server\"\n    }"
    ],
    "utterance": "Combine all values of the service.name field into a single string separated by a comma and space, alongside the number field.",
    "expressions": [
      ".group[].group[] | { \"number\": .number, \"service name\": ([.service[].name]|join(\", \")) }"
    ],
    "data": [
      {
        "input": {
          "group": [
            {
              "group": [
                {
                  "number": 1,
                  "service": [
                    {
                      "name": "FTP-Server",
                      "port": "21",
                      "type": "service-tcp",
                      "uid": "ef245528-9a3d-11d6-9eaa-3e5a6fdd6a6a"
                    },
                    {
                      "name": "SSH-Server",
                      "port": "22",
                      "type": "service-tcp",
                      "uid": "dff4f7ba-9a3d-11d6-91c1-3e5a6fdd5151"
                    }
                  ],
                  "uid": "90088436-ac42-4363-84a6-3dbebf3c11f0"
                }
              ]
            }
          ]
        },
        "output": {
          "number": 1,
          "service name": "FTP-Server, SSH-Server"
        }
      }
    ],
    "identifier": 52588722
  },
  {
    "context": [
      "no matter what i do, when I take raw input in slurp mode and output the JSON, the last item in the array is blank (\"\").",
      "Either remove the final newline, or omit the empty element at the end of the array.",
      "jq -R -s '.[:-1] | split(\"\\n\")'",
      "jq -R -s 'split(\"\\n\")[:-1]'",
      "jq -R -s 'sub(\"\\n$\";\"\") | split(\"\\n\")'",
      "jq -nR '[inputs]'",
      "rpm -qa | grep kernel | jq -R . | jq -s ."
    ],
    "utterance": "Convert multi-line shell output into an array of lines, excluding any trailing empty element caused by a final newline.",
    "expressions": [
      "jq -R -s 'split(\"\\n\")[:-1]'",
      "jq -R -s '.[:-1] | split(\"\\n\")'",
      "jq -R -s 'sub(\"\\n$\";\"\") | split(\"\\n\")'",
      "jq -nR '[inputs]'",
      "jq -R . | jq -s ."
    ],
    "data": [
      {
        "input": "foo\nbar\n",
        "output": [
          "foo",
          "bar"
        ]
      },
      {
        "input": "foo\nbar",
        "output": [
          "foo",
          "bar"
        ]
      }
    ],
    "identifier": 52620027
  },
  {
    "context": [
      "I want to select() an object based on a string containing a jq variable ($ARCH) using -arg jq argument.",
      "jq --arg ARCH amd64 '[.ListBucketResult.Contents[] | select(.Key | contains(\"/bin/linux/$arch/kubeadm\"))]'",
      "...which returns an empty set because jq doesn't transliterate inside quotes.",
      "jq does support string interpolation, and in your case the string would be:",
      "\"/bin/linux/\\($ARCH)/kubeadm\"",
      "Alternatively, you could of course use string concatenation: \"/bin/linux/\" + $ARCH + \"/kubeadm\""
    ],
    "utterance": "Select objects where the Key field contains the substring /bin/linux/amd64/kubeadm, using a variable for amd64.",
    "expressions": [
      "[.ListBucketResult.Contents[] | select(.Key | contains(\"/bin/linux/\u0000($ARCH)/kubeadm\"))]",
      "[.ListBucketResult.Contents[] | select(.Key | contains(\"/bin/linux/\" + $ARCH + \"/kubeadm\"))]"
    ],
    "identifier": 52672234
  },
  {
    "context": [
      "I want to find the t values from a.json, which are between any single range t1, t2 of b.json objects.",
      "So expected output is\n\n    {\n      \"t\": 3\n    }\n    {\n      \"t\": 13\n    }",
      "You can use this `jq` filter:\n\n    jq --slurpfile a a.json --slurpfile b b.json -n \\\n      '$a[] | [.t] | if inside($b[] | [ range(.t1; .t2+1) ]) then {t:.[]} else empty end'",
      "The following solution is oriented to efficiency and also handles the case where the intervals defined by b.json overlap:\n\n    < a.json jq --slurpfile b b.json '\n      def check($value):\n        if any(.[]; .t1 <= $value and $value <= .t2) \n        then {t:$value} \n        else empty\n        end ;\n      . as $a | $b | check($a.t)\n    ' "
    ],
    "utterance": "Find all objects from a.json whose t value falls within any t1-t2 range specified in b.json.",
    "expressions": [
      "$a[] | [.t] | if inside($b[] | [ range(.t1; .t2+1) ]) then {t:.[]} else empty end",
      "def check($value): if any(.[]; .t1 <= $value and $value <= .t2) then {t:$value} else empty end; . as $a | $b | check($a.t)"
    ],
    "data": [
      {
        "input": [
          {
            "t": 3
          },
          {
            "t": 6
          },
          {
            "t": 13
          }
        ],
        "output": [
          {
            "t": 3
          },
          {
            "t": 13
          }
        ]
      },
      {
        "input": [
          {
            "t1": 1,
            "t2": 4
          },
          {
            "t1": 7,
            "t2": 8
          },
          {
            "t1": 11,
            "t2": 13
          }
        ]
      }
    ],
    "identifier": 52643251
  },
  {
    "context": [
      "I need to replace the keys inside the nested JSON key \"kruxSegmentIds\" in such a way that 0 becomes \"zero\" and 1 as \"one\" like below:\r\n\r\n    {\"callsign\":\"abc\",\"kruxSegmentIds\":{\"zero\":\"q2d9nn1qv\",\"one\":\"rle4kfgsf\"},\"liveFlag\":\"Y\"}}",
      "jq '.kruxSegmentIds |= with_entries(.key |= if .==\"0\" then \"zero\" elif .==\"1\" then \"one\" else . end)'"
    ],
    "utterance": "Replace the keys '0' and '1' inside the 'kruxSegmentIds' object with 'zero' and 'one' respectively.",
    "expressions": [
      ".kruxSegmentIds |= with_entries(.key |= if .==\"0\" then \"zero\" elif .==\"1\" then \"one\" else . end)"
    ],
    "data": [
      {
        "input": {
          "callsign": "abc",
          "kruxSegmentIds": {
            "0": "q2d9nn1qv",
            "1": "rle4kfgsf"
          },
          "liveFlag": "Y"
        },
        "output": {
          "callsign": "abc",
          "kruxSegmentIds": {
            "zero": "q2d9nn1qv",
            "one": "rle4kfgsf"
          },
          "liveFlag": "Y"
        }
      }
    ],
    "identifier": 52695178
  },
  {
    "context": [
      "'.contact_methods[] | select(.label == \"Mobile\") | .address'",
      "Use baskslash before the single quote of the jq filter:",
      "| jq \\\\'.contact_methods[] | select(.label == \\\"Mobile\\\") | .address\\\\'';"
    ],
    "utterance": "Extract the address field from all contact_methods where label is equal to \"Mobile\".",
    "expressions": [
      ".contact_methods[] | select(.label == \"Mobile\") | .address"
    ],
    "identifier": 52698257
  },
  {
    "context": [
      "I am trying to use jq to convert something like this:",
      "[{\"type\": \"Feature\",\"properties\": {\"osm_id\": \"172544\",\"highway\": \"crossing\",\"other_tags\": \"\\\"crossing\\\"=>\\\"uncontrolled\\\",\\\"tactile_paving\\\"=>\\\"yes\\\"\"},\"geometry\": {\"type\": \"Point\",\"coordinates\": [13.3432342,52.5666157]}}]",
      "into this:",
      "[{\"type\": \"Feature\",\"properties\": {\"osm_id\": \"172544\",\"highway\": \"crossing\",\"other_tags\": {\"crossing\": \"uncontrolled\",\"tactile_paving\": \"yes\"}},\"geometry\": {\"type\": \"Point\",\"coordinates\": [13.3432342,52.5666157]}}]",
      "You could also use this:",
      "[.[] | try(.properties.other_tags |= (\"{\" + gsub(\"=>\"; \":\") + \"}\" | fromjson))//.]",
      "found a satisfying solution while fiddling around on [jqplay][1]:",
      "jq '.features\n  | map(try(.properties.other_tags |=\n            (split(\"\\\",\\\"\")\n             | join(\"\\\"##strsplit##\\\"\")\n             | split(\"##strsplit##\")\n             | .[] |= split(\"=>\") \n             | .[] |= {(.[0][1:-1]): (.[1][1:-1])}\n             | add)) // .)'"
    ],
    "utterance": "Convert the 'other_tags' string with entries like '\"crossing\"=>\"uncontrolled\",\"tactile_paving\"=>\"yes\"' into a nested object mapping keys to values within all features' properties.",
    "expressions": [
      ".[] | try(.properties.other_tags |= (\"{\" + gsub(\"=>\"; \":\") + \"}\" | fromjson)) // .",
      ".features | map(try(.properties.other_tags |= (split(\",\") | map(split(\"=>\")) | map({(.[0][1:-1]): (.[1][1:-1])}) | add)) // .)",
      "map(.properties.other_tags |= ([.properties.other_tags | split(\",\") | map(split(\"=>\")) | map({(.[0][1:-1]): (.[1][1:-1])})] | add))"
    ],
    "data": [
      {
        "input": [
          {
            "type": "Feature",
            "properties": {
              "osm_id": "172544",
              "highway": "crossing",
              "other_tags": "\"crossing\"=>\"uncontrolled\",\"tactile_paving\"=>\"yes\""
            },
            "geometry": {
              "type": "Point",
              "coordinates": [
                13.3432342,
                52.5666157
              ]
            }
          }
        ],
        "output": [
          {
            "type": "Feature",
            "properties": {
              "osm_id": "172544",
              "highway": "crossing",
              "other_tags": {
                "crossing": "uncontrolled",
                "tactile_paving": "yes"
              }
            },
            "geometry": {
              "type": "Point",
              "coordinates": [
                13.3432342,
                52.5666157
              ]
            }
          }
        ]
      }
    ],
    "identifier": 52645978
  },
  {
    "context": [
      "I want to change the sub number in the \"IntendedFor\" line using a bash variable, looping over different subs.For example if sub is 03:",
      "How can I change the value of `sub-02` to `sub-03` using this bash variable?",
      "jq --arg sub \"$sub\" '.IntendedFor |= sub(\"(?<=sub-)[^_]+\"; $sub)' file",
      "for f in *.json; do\n  jq --arg sub \"$sub\" '.IntendedFor |= sub(\"/sub-[^_]+\";\"/sub-\"+$sub)' \"$f\" | sponge \"$f\"\ndone"
    ],
    "utterance": "Replace the number after 'sub-' in the 'IntendedFor' field with the value of a shell variable.",
    "expressions": [
      "jq --arg sub \"$sub\" '.IntendedFor |= sub(\"(?<=sub-)[^_]+\"; $sub)' file",
      "jq --arg sub \"$sub\" '.IntendedFor |= sub(\"/sub-[^_]+\";\"/sub-\"+$sub)' file"
    ],
    "data": [
      {
        "input": {
          "AcquisitionNumber": 1,
          "TotalReadoutTime": 0.035,
          "IntendedFor": "func/sub-02_task-rest_run-01_bold.nii.gz"
        },
        "output": {
          "AcquisitionNumber": 1,
          "TotalReadoutTime": 0.035,
          "IntendedFor": "func/sub-03_task-rest_run-01_bold.nii.gz"
        }
      }
    ],
    "identifier": 52689219
  },
  {
    "context": [
      "You can use `jq` and its `tonumber` function to change the wanted strings to values:",
      "<file jq '[].timestamp |= tonumber | .[].score |= tonumber'",
      "For reference, if there's any doubt about where the relevant keys are located, here's a filter in jq that is agnostic about that:",
      "`walk(if type == \"object\" \n         then if has(\"timestamp\") then .timestamp|=tonumber else . end\n         | if has(\"score\") then .score|=tonumber else end \n         else . end)`"
    ],
    "utterance": "Convert the values of the keys \"timestamp\" and \"score\" from strings to numbers wherever they appear in the data.",
    "expressions": [
      ".[].timestamp |= tonumber | .[].score |= tonumber",
      "walk(if type == \"object\" then if has(\"timestamp\") then .timestamp |= tonumber else . end | if has(\"score\") then .score |= tonumber else . end else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "title": "DNS domain",
            "timestamp": "1538564256",
            "domain": {
              "dns": [
                "www.google.com"
              ]
            },
            "score": "10",
            "link": "www.bit.ky/sdasd/asddsa",
            "id": "c-1eOWYB9XD0VZRJuWL6"
          },
          {
            "title": "DNS domain",
            "timestamp": "1538564256",
            "domain": {
              "dns": [
                "google.de"
              ]
            },
            "score": "10",
            "link": "www.bit.ky/sdasd/asddsa",
            "id": "du1eOWYB9XD0VZRJuWL6"
          }
        ],
        "output": [
          {
            "title": "DNS domain",
            "timestamp": 1538564256,
            "domain": {
              "dns": [
                "www.google.com"
              ]
            },
            "score": 10,
            "link": "www.bit.ky/sdasd/asddsa",
            "id": "c-1eOWYB9XD0VZRJuWL6"
          },
          {
            "title": "DNS domain",
            "timestamp": 1538564256,
            "domain": {
              "dns": [
                "google.de"
              ]
            },
            "score": 10,
            "link": "www.bit.ky/sdasd/asddsa",
            "id": "du1eOWYB9XD0VZRJuWL6"
          }
        ]
      }
    ],
    "identifier": 52626648
  },
  {
    "context": [
      "I\u2019m trying to get this into a format that another language that isn\u2019t super friendly to JSON can handle more easily by condensing it into something like this:\n\n    {\"matches\":\n        [\n         {\n          \"team1\": \"San Francisco Shock\",\n          \"t1score\": \"0\",\n          \"team2\": \"Los Angeles Valiant\",\n          \"t2score\": \"4\"\n         },\n         { ... }\n        ]\n    }",
      "The trick is to \"pull\" the `.weeks[]` iterator forward, and to `map` over the `.matches` array:\n\n    .stage[]\n    |.weeks[]\n    | {matches:\n        (.matches\n         | map({team1:   .teams[0].name,\n                t1score: .teams[0].score,\n    \t        team2:   .teams[1].name, \n                t2score: .teams[1].score }) ) }",
      "# Output\n\n    {\n      \"matches\": [\n        {\n          \"team1\": \"San Francisco Shock\",\n          \"t1score\": \"0\",\n          \"team2\": \"Los Angeles Valiant\",\n          \"t2score\": \"4\"\n        },\n        {\n          \"team1\": \"Shanghai Dragons\",\n          \"t1score\": \"0\",\n          \"team2\": \"Los Angeles Gladiators\",\n          \"t2score\": \"4\"\n        },\n        {\n          \"team1\": \"Dallas Fuel\",\n          \"t1score\": \"1\",\n          \"team2\": \"Seoul Dynasty\",\n          \"t2score\": \"2\"\n        }\n      ]\n    }"
    ],
    "utterance": "Extract an array of objects for each match, each containing team1, t1score, team2, and t2score fields, from all matches in all weeks of all stages.",
    "expressions": [
      ".stage[] | .weeks[] | {matches: (.matches | map({team1: .teams[0].name, t1score: .teams[0].score, team2: .teams[1].name, t2score: .teams[1].score }))}"
    ],
    "data": [
      {
        "input": {
          "stage": [
            {
              "name": "Stage 1",
              "weeks": [
                {
                  "name": "Week 1",
                  "matches": [
                    {
                      "teams": [
                        {
                          "name": "San Francisco Shock",
                          "score": "0",
                          "score_url": "https://overwatchleague.com/matches/10223"
                        },
                        {
                          "name": "Los Angeles Valiant",
                          "score": "4",
                          "score_url": "https://overwatchleague.com/matches/10223"
                        }
                      ]
                    },
                    {
                      "teams": [
                        {
                          "name": "Shanghai Dragons",
                          "score": "0",
                          "score_url": "https://overwatchleague.com/matches/10224"
                        },
                        {
                          "name": "Los Angeles Gladiators",
                          "score": "4",
                          "score_url": "https://overwatchleague.com/matches/10224"
                        }
                      ]
                    },
                    {
                      "teams": [
                        {
                          "name": "Dallas Fuel",
                          "score": "1",
                          "score_url": "https://overwatchleague.com/matches/10225"
                        },
                        {
                          "name": "Seoul Dynasty",
                          "score": "2",
                          "score_url": "https://overwatchleague.com/matches/10225"
                        }
                      ]
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": {
          "matches": [
            {
              "team1": "San Francisco Shock",
              "t1score": "0",
              "team2": "Los Angeles Valiant",
              "t2score": "4"
            },
            {
              "team1": "Shanghai Dragons",
              "t1score": "0",
              "team2": "Los Angeles Gladiators",
              "t2score": "4"
            },
            {
              "team1": "Dallas Fuel",
              "t1score": "1",
              "team2": "Seoul Dynasty",
              "t2score": "2"
            }
          ]
        }
      }
    ],
    "identifier": 52692955
  },
  {
    "context": [
      "I want to get output as below",
      "{\n  ...\n  \"snstopic\": {\n    \"topic-project1\": \"arn:aws:sns:us-east-2:123456789012:team-project1-dev\",\n    \"topci-project2\": \"arn:aws:sns:us-east-2:123456789012:team-project2-dev\",\n    ...  (different json files have different number of sns topics\n  },\n ...\n}",
      "How to add it in all matched keys in `.snstopic`?",
      "jq --arg prefix \"$ARN_PREFIX\" '\n  .snstopic |= map_values($prefix + .)\n' template.json"
    ],
    "utterance": "Prepend the value of the ARN_PREFIX environment variable to every value in the snstopic object so each topic value becomes a full ARN using us-east-2 and 123456789012.",
    "expressions": [
      ".snstopic |= map_values($prefix + .)"
    ],
    "data": [
      {
        "input": {
          "snstopic": {
            "topic-project1": "team-project1-dev",
            "topci-project2": "team-project2-dev"
          }
        },
        "output": {
          "snstopic": {
            "topic-project1": "arn:aws:sns:us-east-2:123456789012:team-project1-dev",
            "topci-project2": "arn:aws:sns:us-east-2:123456789012:team-project2-dev"
          }
        }
      }
    ],
    "identifier": 52710050
  },
  {
    "context": [
      "But what I want is, I want to pass the key to jq as a bash variable, i.e",
      "bash_var=\"app\"",
      "jq '.\"${bash_var}\"'",
      "I'm getting the output as **null** instead of the value. What is the correct syntax to achieve this?",
      "First, you need to port the `bash` variable into `jq`'s context usign the `--arg` flag and access it inside the `[..]`",
      "jq --arg keyvar \"$bash_var\" '.[$keyvar]' json"
    ],
    "utterance": "Retrieve the value associated with a key whose name is stored in a bash variable, where the key is provided at runtime.",
    "expressions": [
      "jq --arg keyvar \"$bash_var\" '.[$keyvar]'"
    ],
    "data": [
      {
        "input": {
          "app": "K8s",
          "version": "1.8",
          "date": "2018-10-10"
        },
        "output": "K8s"
      }
    ],
    "identifier": 52732473
  },
  {
    "context": [
      "I use jq 1.5 under a Windows environment. I took a look in the manual but found no built in Feature to add Array Position into the element. Any ideas?",
      "To add the array index to the array elements in arr2.json, you could use `reduce`:",
      "jq -f program.jq arr2.json",
      "where program.jq contains:",
      ".currency |= reduce range(0;length) as $i (.; .[$i].Position = 1+$i)",
      "Or, assuming you're in a Windows environment:",
      "jq \".currency |= reduce range(0;length) as $i (.; .[$i].Position = 1+$i)\" arr2.json"
    ],
    "utterance": "Add a Position field to each element of the currency array indicating its 1-based array position.",
    "expressions": [
      ".currency |= reduce range(0;length) as $i (.; .[$i].Position = 1+$i)"
    ],
    "data": [
      {
        "input": {
          "currency": [
            {
              "CODE": "EUR",
              "Name": "Euro"
            },
            {
              "Code": "CAD",
              "Name": "Canadian Dollar"
            }
          ]
        },
        "output": {
          "currency": [
            {
              "CODE": "EUR",
              "Name": "Euro",
              "Position": 1
            },
            {
              "Code": "CAD",
              "Name": "Canadian Dollar",
              "Position": 2
            }
          ]
        }
      }
    ],
    "identifier": 52716707
  },
  {
    "context": [
      "Basically I need to take what's inside the \"data\" part from each file after the first, and merge it into the first file.",
      "To merge the .data elements of all the responses into the first response, you could run:\n\n    jq 'reduce inputs.data as $s (.; .data += $s)' page1.json page2.json ...",
      "Or if you simply want an object of the form {\"data\": [ ... ]} then (again assuming you invoke jq with the -n command-line option) the following jq filter would suffice:\n\n    {data: [inputs.data] | add}"
    ],
    "utterance": "Combine the arrays under the data field from multiple files into a single merged array in one output object.",
    "expressions": [
      "reduce inputs.data as $s (.; .data += $s)",
      "{data: [inputs.data] | add}"
    ],
    "data": [
      {
        "input": [
          {
            "object": "list",
            "total_cards": 290,
            "has_more": true,
            "next_page": "https://api.scryfall.com/cards/search?format=json&include_extras=false&order=set&page=2&q=e%3Alea&unique=cards",
            "data": [
              {
                "object": "card",
                "id": "d5c83259-9b90-47c2-b48e-c7d78519e792",
                "name": "Animate Wall"
              }
            ]
          },
          {
            "object": "list",
            "total_cards": 290,
            "has_more": false,
            "next_page": null,
            "data": [
              {
                "object": "card",
                "id": "b2d6d7cd-f422-44cd-9b03-cf6f3865a3dc",
                "name": "Another Card"
              }
            ]
          }
        ],
        "output": {
          "object": "list",
          "total_cards": 290,
          "has_more": true,
          "next_page": "https://api.scryfall.com/cards/search?format=json&include_extras=false&order=set&page=2&q=e%3Alea&unique=cards",
          "data": [
            {
              "object": "card",
              "id": "d5c83259-9b90-47c2-b48e-c7d78519e792",
              "name": "Animate Wall"
            },
            {
              "object": "card",
              "id": "b2d6d7cd-f422-44cd-9b03-cf6f3865a3dc",
              "name": "Another Card"
            }
          ]
        }
      }
    ],
    "identifier": 52730022
  },
  {
    "context": [
      "Now I'm trying to get the \"id\" number 381, and then to create a new JSON file on the disk when I place the \"id\" number in the right place.",
      "The new JSON file for example:\r\n\r\n    {\r\n      \"request\": {\r\n        \"Event\": {\r\n          \"id\": \"381\",\r\n          \"task\": \"new\"\r\n        }\r\n      }\r\n    }",
      "Given your input, this works:\r\n\r\n    jq -r '{\"request\": {\"Event\": {\"id\": .[0].id, \"task\": \"new\"}}}' > file"
    ],
    "utterance": "Create an object containing {\"request\": {\"Event\": {\"id\": value from the first array element, \"task\": \"new\"}}} using the value of the first element's \"id\" property.",
    "expressions": [
      "{ \"request\": { \"Event\": { \"id\": .[0].id, \"task\": \"new\" } } }"
    ],
    "data": [
      {
        "input": [
          {
            "id": "381",
            "org_id": "9",
            "date": "2018-10-10",
            "info": "THIS IS TEST",
            "uuid": "5bbd1b41bc",
            "published": 1,
            "an": "2",
            "attribute_count": "4",
            "orgc_id": "8",
            "timestamp": "1",
            "dEST": "0",
            "sharing": "0",
            "proposal": false,
            "locked": false,
            "level_id": "1",
            "publish_timestamp": "0",
            "disable_correlation": false,
            "extends_uuid": "",
            "Org": {
              "id": "5",
              "name": "test",
              "uuid": "5b9bc"
            },
            "Orgc": {
              "id": "1",
              "name": "test",
              "uuid": "5b9f93bdeac1b41bc"
            },
            "ETag": []
          }
        ],
        "output": {
          "request": {
            "Event": {
              "id": "381",
              "task": "new"
            }
          }
        }
      }
    ],
    "identifier": 52736476
  },
  {
    "context": [
      "I have a nested json object like so:\r\n\r\n    {\r\n      \"results\": {\r\n        \"category_a\": {\r\n          \"types\": {\r\n            \"type_a\": {},\r\n            \"type_b\": {},\r\n            \"type_c\": {}\r\n          }\r\n        },\r\n        \"category_b\": {\r\n          \"types\": {\r\n            \"type_y\": {},\r\n            \"type_z\": {}\r\n          }\r\n        }\r\n      }\r\n    }\r\n",
      "and I'd like to squash it down it into a simpler nested object:\r\n\r\n    {\r\n      \"category_a\": [\r\n        \"type_a\",\r\n        \"type_b\",\r\n        \"type_c\"\r\n      ],\r\n      \"category_b\": [\r\n        \"type_y\",\r\n        \"type_z\"\r\n      ]\r\n    }\r\n",
      "This is what I have so far, which is close to what I want:\r\n\r\n    .results\r\n    | to_entries[]\r\n    | {\r\n        (.key): [\r\n          .value.types | keys[]\r\n        ]\r\n      }\r\n\r\nexcept that the output is line-oriented instead of being a single object:",
      "How can I combine those two json objects into one?",
      "Working with your program as a starting point, you can simply wrap the separate objects in square brackets, and then use `add`:\r\n\r\n    .results\r\n    | [to_entries[] | { (.key): [ .value.types | keys[] ] } ]\r\n    | add"
    ],
    "utterance": "Transform an object with nested categories each containing a types object into an object whose keys are the categories and whose values are arrays of type names.",
    "expressions": [
      ".results | [to_entries[] | { (.key): [ .value.types | keys[] ] } ] | add"
    ],
    "data": [
      {
        "input": {
          "results": {
            "category_a": {
              "types": {
                "type_a": {},
                "type_b": {},
                "type_c": {}
              }
            },
            "category_b": {
              "types": {
                "type_y": {},
                "type_z": {}
              }
            }
          }
        },
        "output": {
          "category_a": [
            "type_a",
            "type_b",
            "type_c"
          ],
          "category_b": [
            "type_y",
            "type_z"
          ]
        }
      }
    ],
    "identifier": 52748294
  },
  {
    "identifier": 52761772
  },
  {
    "context": [
      "I have the date in the file which looks like \n\n    test,test\n    test1,test1\n\nI want to convert it into like:\n\n    {\"test\":\"test\",\"test1\":\"test1\"}",
      "jq 1.5 has `inputs`, which allows a simple and efficient solution:\n\n     jq -R -n -c '[inputs|split(\",\")|{(.[0]):.[1]}] | add' input.txt",
      "Otherwise:\n\n    jq -R -s '\n      split(\"\\n\")\n      | map(if index(\",\") then split(\",\")|{(.[0]):.[1]}\n            else empty end)\n      | add' input.txt",
      "jq -Rn '[inputs|split(\",\")| {(.[0]): .[1]}] | reduce .[] as $obj ({}; . + $obj) ' input.csv"
    ],
    "utterance": "Convert a file containing comma-separated key-value pairs, one pair per line, into an object mapping each key to its corresponding value.",
    "expressions": [
      "jq -R -n -c '[inputs|split(\",\")|{(.[0]):.[1]}] | add'",
      "jq -R -s 'split(\"\\n\") | map(if index(\",\") then split(\",\")|{(.[0]):.[1]} else empty end) | add'",
      "jq -Rn '[inputs|split(\",\")| {(.[0]): .[1]}] | reduce .[] as $obj ({}; . + $obj)'"
    ],
    "data": [
      {
        "input": "test,test\ntest1,test1\n",
        "output": {
          "test": "test",
          "test1": "test1"
        }
      }
    ],
    "identifier": 52760882
  },
  {
    "context": [
      "Need to take the last array .rental_methods and concatenate them into 1 line, colon separated.",
      "I get the error `string (\"5343\") cannot be csv-formatted, only array`",
      "With your JSON, this would produce:\n\n    1539122087,\"5343\",\"Lot\",\"461\",\"Austin\",\"KEY:APPLEPAY:ANDROIDPAY:TRANSITCARD:ACCOUNTNUMBER:PHONE\"\n\n... which is not quite what you've said you want.  Changing the last line to:\n\n    map(tostring) | join(\",\")\n\nresults in:\n\n    1539122087,5343,Lot,461,Austin,KEY:APPLEPAY:ANDROIDPAY:TRANSITCARD:ACCOUNTNUMBER:PHONE\n\nThis is exactly what you've indicated you want except for the terminating punctuation, which you can easily add (e.g. by appending `+ \",\"` to the program above) if so desired.",
      "jq -r '.last_updated as $lu\n  | .data[][]\n  | [$lu, .station_id, .name, .region_id, .address, (.rental_methods | join(\":\")) ]\n  | @csv'"
    ],
    "utterance": "Produce a single line containing last_updated, station_id, name, region_id, address, and the rental_methods concatenated with colon separators, separated by commas.",
    "expressions": [
      ".last_updated as $lu | .data[][] | [$lu, .station_id, .name, .region_id, .address, (.rental_methods | join(\":\"))] | map(tostring) | join(\",\")",
      ".last_updated as $lu | .data[][] | [$lu, .station_id, .name, .region_id, .address, (.rental_methods | join(\":\")) ] | @csv"
    ],
    "data": [
      {
        "input": {
          "last_updated": 1539122087,
          "ttl": 60,
          "data": {
            "stations": [
              {
                "station_id": "5343",
                "name": "Lot",
                "region_id": "461",
                "address": "Austin",
                "rental_methods": [
                  "KEY",
                  "APPLEPAY",
                  "ANDROIDPAY",
                  "TRANSITCARD",
                  "ACCOUNTNUMBER",
                  "PHONE"
                ]
              }
            ]
          }
        },
        "output": [
          "1539122087,5343,Lot,461,Austin,KEY:APPLEPAY:ANDROIDPAY:TRANSITCARD:ACCOUNTNUMBER:PHONE"
        ]
      }
    ],
    "identifier": 52746668
  },
  {
    "context": [
      "I have two file json. I want to append two array of SomeFile2.json to SomeFile1.json as below.",
      "I want the result as below:",
      "Then, update the instances in the first file:\n\n    jq --argjson states \"$state_map\" '[].Instances[] |= . + {\"State\": ($states[.InstanceId] // \"unknown\")}' SomeFile1.json",
      "Putting the pieces together in program.jq:\n\n    (reduce $dict[] as $x ({}; . + ($x|{(.InstanceId): .State}))) as $d\n    | map(.Instances |= map(. + {State: $d[.InstanceId]}))",
      "Another alternative is to use `INDEX/2`: \n\n    (INDEX($dict[]; .InstanceId) | map_values(.State))) as $d"
    ],
    "utterance": "Add the State property from a list of instance states to each corresponding instance within a list of load balancers, matching by InstanceId.",
    "expressions": [
      "jq --argjson states \"$state_map\" '.[].Instances[] |= . + {\"State\": ($states[.InstanceId] // \"unknown\")}' SomeFile1.json",
      "(reduce $dict[] as $x ({}; . + ($x|{(.InstanceId): .State}))) as $d | map(.Instances |= map(. + {State: $d[.InstanceId]}))",
      "($dict | map( {(.InstanceId): .State}) | add) as $d | map(.Instances |= map(. + {State: $d[.InstanceId]}))",
      "(INDEX($dict[]; .InstanceId) | map_values(.State)) as $d | map(.Instances |= map(. + {State: $d[.InstanceId]}))"
    ],
    "data": [
      {
        "input": [
          {
            "DNSName": "CLB-test-112a877451.ap-northeast-1.elb.amazonaws.com",
            "Instances": [
              {
                "InstanceId": "i-0886ed703de64028a"
              }
            ]
          },
          {
            "DNSName": "CLB-test1-156925981.ap-northeast-1.elb.amazonaws.com",
            "Instances": [
              {
                "InstanceId": "i-0561634c4g3b4fa25"
              }
            ]
          }
        ],
        "output": [
          {
            "DNSName": "CLB-test-112a877451.ap-northeast-1.elb.amazonaws.com",
            "Instances": [
              {
                "InstanceId": "i-0886ed703de64028a",
                "State": "InService"
              }
            ]
          },
          {
            "DNSName": "CLB-test1-156925981.ap-northeast-1.elb.amazonaws.com",
            "Instances": [
              {
                "InstanceId": "i-0561634c4g3b4fa25",
                "State": "InService"
              }
            ]
          }
        ]
      },
      {
        "input": [
          {
            "InstanceId": "i-0886ed703de64028a",
            "State": "InService"
          },
          {
            "InstanceId": "i-0561634c4g3b4fa25",
            "State": "InService"
          }
        ]
      }
    ],
    "identifier": 52744308
  },
  {
    "context": [
      "The SERVICE_MANIFEST is content of another json file",
      "Any ideas? The final result still should be a valid json file",
      "A simple solution would use `--argfile` and avoid `select`:\r\n\r\n    < source.json jq --argfile sm service_manifest.json '\r\n      .containerDefinitions[0].environment[0].value = $sm ' ",
      "Or if you want only to update the object(s) with `.name == \"SERVICE_MANIFEST\"` you could use the filter:\r\n\r\n    .containerDefinitions[].environment \r\n      |= map(if .name == \"SERVICE_MANIFEST\"\r\n             then .value = $sm \r\n             else . end)"
    ],
    "utterance": "Replace the value of the environment object with name equal to SERVICE_MANIFEST in containerDefinitions with the contents of another file.",
    "expressions": [
      ".containerDefinitions[].environment |= map(if .name == \"SERVICE_MANIFEST\" then .value = $sm else . end)"
    ],
    "data": [
      {
        "input": {
          "AWSEBDockerrunVersion": 2,
          "containerDefinitions": [
            {
              "environment": [
                {
                  "name": "SERVICE_MANIFEST",
                  "value": ""
                },
                {
                  "name": "SERVICE_PORT",
                  "value": "4321"
                }
              ]
            }
          ]
        },
        "output": {
          "AWSEBDockerrunVersion": 2,
          "containerDefinitions": [
            {
              "environment": [
                {
                  "name": "SERVICE_MANIFEST",
                  "value": {
                    "connections": {
                      "port": "1234"
                    },
                    "name": "foo"
                  }
                },
                {
                  "name": "SERVICE_PORT",
                  "value": "4321"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 52736675
  },
  {
    "context": [
      "I want to add \"stable\": \"yes\" to every object in this file with jq. How can i do this?",
      "`map` and `+` will do this:",
      "$ jq 'map(. + {stable: \"yes\"})' tmp.json",
      "Note this will also override any existing `stable` key in each object."
    ],
    "utterance": "Add the key stable with value yes to every object in the input array.",
    "expressions": [
      "map(. + {stable: \"yes\"})"
    ],
    "data": [
      {
        "input": [
          {
            "id": "1",
            "name": "Blue"
          },
          {
            "id": "2",
            "name": "Red"
          }
        ],
        "output": [
          {
            "id": "1",
            "name": "Blue",
            "stable": "yes"
          },
          {
            "id": "2",
            "name": "Red",
            "stable": "yes"
          }
        ]
      }
    ],
    "identifier": 52762589
  },
  {
    "context": [
      "Now, I would like to count the number of torrents that are currently dowloading, seeding or on pause. I\u2019m only interested by the `state`, so if I have 6 torrents, my JSON could look like that:",
      "What do I need to do to get the details such as 3 are downloading, 1 is uploading, 2 are paused and 0 are in error?",
      "The WebUI API says there are 12 different possible states. That\u2019s how I intend to split them up:\n\ndownloading: queuedDL, checkingDL, downloading\nuploading: queuedUP, checkingUP, uploading\npause: pausedUP, pausedDL\nerror: error\nstalled: stalledUP, stalledDL, metaDL",
      "If you need entries for *all* values, even ones which have no occurrence, you might consider:\n\n    jq -r '\n      def filterStates($stateMap):\n        if $stateMap[.] then $stateMap[.] else . end;\n    \n      def errorLevel:\n        if (.[\"error\"] > 0) then 2 else\n          if (.[\"stalled\"] > 0) then 1 else\n            0\n          end\n        end;\n    \n      {\"queuedDL\": \"downloading\", \n       \"checkingDL\": \"downloading\",\n       \"queuedUP\": \"uploading\", \n       \"checkingUP\": \"uploading\",\n       \"pausedUP\": \"pause\", \n       \"pausedDL\": \"pause\",\n       \"stalledUP\": \"stalled\", \n       \"stalledDL\": \"stalled\", \n       \"metaDL\": \"stalled\"} as $stateMap |\n    \n      # initialize an output array since we want 0 outputs for everything\n      {\"pause\": 0,  \"stalled\": 0, \"error\": 0, \"downloading\": 0, \"uploading\": 0} as $counts |\n    \n      # count number of items which filter to each value\n      reduce (.[].state | filterStates($stateMap)) as $state ($counts; .[$state]+=1) |\n    \n      # actually format an output string\n      \"\\(. | errorLevel) qbt_Nb_torrents - \\(values | add) total, \\(. [\\\"downloading\\\"]) downloading, \\(. [\\\"uploading\\\"]) seeding, \\(. [\\\"pause\\\"]) on pause, \\(. [\\\"stalled\\\"]) stalled, \\(. [\\\"error\\\"]) error\"\n    ' /tmp/torrents.json",
      "# count number of items which filter to each value\n      reduce (.[].state | filterStates($stateMap)) as $state ($counts; .[$state]+=1) |",
      "*def bow(init; s): reduce s as $word (init; .[$word] += 1) ;*",
      "*bow(init; .[].state | filterStates(stateMap))\n  | \"\\(errorLevel) qbt_Nb_torrents - \\(values | add) total, \\(.downloading) downloading, \\(.uploading) seeding, \\(.pause) on pause, \\(.stalled) stalled, \\(.error) error\"*"
    ],
    "utterance": "Count the number of torrent entries grouped into categories (downloading, uploading, pause, stalled, error) according to a mapping of raw states, and output a formatted status line showing the counts for each category, reporting zero for any with no occurrences.",
    "expressions": [
      "jq -r '\n  def filterStates($stateMap):\n    if $stateMap[.] then $stateMap[.] else . end;\n\n  def errorLevel:\n    if (.[\"error\"] > 0) then 2 else\n      if (.[\"stalled\"] > 0) then 1 else\n        0\n      end\n    end;\n\n  {\"queuedDL\": \"downloading\", \n   \"checkingDL\": \"downloading\",\n   \"queuedUP\": \"uploading\", \n   \"checkingUP\": \"uploading\",\n   \"pausedUP\": \"pause\", \n   \"pausedDL\": \"pause\",\n   \"stalledUP\": \"stalled\", \n   \"stalledDL\": \"stalled\", \n   \"metaDL\": \"stalled\"} as $stateMap |\n\n  {\"pause\": 0,  \"stalled\": 0, \"error\": 0, \"downloading\": 0, \"uploading\": 0} as $counts |\n\n  reduce (.[].state | filterStates($stateMap)) as $state ($counts; .[$state]+=1) |\n\n  \"\\(. | errorLevel) qbt_Nb_torrents - \\(values | add) total, \\(. [\\\"downloading\\\"]) downloading, \\(. [\\\"uploading\\\"]) seeding, \\(. [\\\"pause\\\"]) on pause, \\(. [\\\"stalled\\\"]) stalled, \\(. [\\\"error\\\"]) error\"\n' /tmp/torrents.json",
      "def bow(init; s): reduce s as $word (init; .[$word] += 1) ;\ndef init:\n  {} | {pause,stalled,error,downloading,uploading} | map_values(0);\ndef filterStates($stateMap):\n  if $stateMap[.] then $stateMap[.] else . end ;\ndef errorLevel:\n  if .error > 0 then 2\n  elif .stalled > 0 then 1\n  else 0\n  end ;\ndef stateMap:\n  {\"queuedDL\": \"downloading\", \n   \"checkingDL\": \"downloading\",\n   \"queuedUP\": \"uploading\", \n   \"checkingUP\": \"uploading\",\n   \"pausedUP\": \"pause\", \n   \"pausedDL\": \"pause\",\n   \"stalledUP\": \"stalled\", \n   \"stalledDL\": \"stalled\", \n   \"metaDL\": \"stalled\"} ;\n\nbow(init; .[].state | filterStates(stateMap))\n| \"\\(errorLevel) qbt_Nb_torrents - \\(values | add) total, \\(.downloading) downloading, \\(.uploading) seeding, \\(.pause) on pause, \\(.stalled) stalled, \\(.error) error\""
    ],
    "data": [
      {
        "input": [
          {
            "state": "uploading"
          },
          {
            "state": "downloading"
          },
          {
            "state": "downloading"
          },
          {
            "state": "downloading"
          },
          {
            "state": "pauseDL"
          },
          {
            "state": "pauseUP"
          }
        ],
        "output": "0 qbt_Nb_torrents - 6 total, 3 downloading, 1 seeding, 2 on pause, 0 stalled, 0 error"
      }
    ],
    "identifier": 52558120
  },
  {
    "context": [
      "I use jq 1.5 under a Windows enviroment to modify a given large json file to extract a single Array (\"Offers\") from that large file:",
      "'.Offers[] | ({Price: .AdultPriceEUR, Currency: .Currency, Link: .Deeplink, Tickettyp: .TicketClassIndex, Flightindex: .FlightIndex })'",
      "After that i got an \"unnamed\" Array. But for the later processing it is necessary that the Array keeps his old \"Name\".",
      "Looks like you're looking at this:",
      "jq '{Offers:[.Offers[] | {Price: .AdultPriceEUR, Currency: .Currency, Link: .Deeplink, Tickettyp: .TicketClassIndex, Flightindex: .FlightIndex }]}' file",
      "It just creates a new object containing an `Offers` table with the content you want to put it it."
    ],
    "utterance": "Extract the Offers array, transforming each element to only include Price from AdultPriceEUR, Currency, Link from Deeplink, Tickettyp from TicketClassIndex, and Flightindex from FlightIndex, while keeping the top-level key 'Offers'.",
    "expressions": [
      "{Offers:[.Offers[] | {Price: .AdultPriceEUR, Currency: .Currency, Link: .Deeplink, Tickettyp: .TicketClassIndex, Flightindex: .FlightIndex }]}"
    ],
    "data": [
      {
        "input": {
          "Airports": [
            {
              "Aliases": null,
              "ContinentCode": "EU",
              "ContinentGroup": 1,
              "CountryCode": "DE",
              "CountryName": "Germany",
              "DST": "",
              "DisplayName": "Hamburg (HAM) Germany",
              "Iata": "HAM",
              "IataLink": false,
              "Icao": "EDDH",
              "Latitude": 53.63215,
              "Longitude": 10.0041609,
              "MainCityCode": "HAM",
              "MainCityDisplayName": "Hamburg (HAM) Germany",
              "MainCityName": "Hamburg",
              "Name": "Hamburg",
              "Priority": 142,
              "StateCode": null,
              "StateName": null,
              "TimeZone": -798214753
            },
            {
              "Aliases": null,
              "ContinentCode": "AS",
              "ContinentGroup": 4,
              "CountryCode": "TH",
              "CountryName": "Thailand",
              "DST": "",
              "DisplayName": "Suvarnabhumi, Bangkok (BKK) Thailand",
              "Iata": "BKK",
              "IataLink": false,
              "Icao": "VTBS",
              "Latitude": 13.6922979,
              "Longitude": 100.750694,
              "MainCityCode": "BKK",
              "MainCityDisplayName": "Bangkok (BKK) Thailand",
              "MainCityName": "Bangkok",
              "Name": "Suvarnabhumi",
              "Priority": 1462,
              "StateCode": null,
              "StateName": null,
              "TimeZone": -640089798
            }
          ],
          "Offers": [
            {
              "AdultPrice": 2977.6,
              "AdultPriceEUR": 2977.6,
              "AdultPriceExclTax": 0.0,
              "Currency": "EUR",
              "FeeIndexes": [
                0,
                1,
                2,
                3,
                4,
                5,
                6
              ],
              "FlightIndex": 0,
              "IsPaymentIncluded": true,
              "MobileDeepLink": null,
              "PaymentMethods": [
                "American Express",
                "Diners Club",
                "MasterCard Credit",
                "MasterCard Debit",
                "Paypal",
                "Visa Credit",
                "Visa Debit"
              ],
              "Score": 2501.3,
              "SegmentFares": null,
              "SegmentKey": -1,
              "TicketClassIndex": 1,
              "TotalIsCalculated": false,
              "TotalPrice": 2977.6,
              "TotalPriceEUR": 2977.6,
              "TotalPriceExclTax": 0.0
            },
            {
              "AdultPrice": 4697.27,
              "AdultPriceEUR": 4697.27,
              "AdultPriceExclTax": 0.0,
              "Currency": "EUR",
              "FeeIndexes": [
                0,
                1,
                2,
                3,
                4,
                7,
                8,
                5,
                6
              ],
              "FlightIndex": 1,
              "IsPaymentIncluded": true,
              "MobileDeepLink": null,
              "PaymentMethods": [
                "American Express",
                "Diners Club",
                "MasterCard Credit",
                "MasterCard Debit",
                "Paypal",
                "Sofort\u00fcberweisung",
                "\u00dcberweisung",
                "Visa Credit",
                "Visa Debit"
              ],
              "Score": 3438.64,
              "SegmentFares": null,
              "SegmentKey": -1,
              "TicketClassIndex": 1,
              "TotalIsCalculated": false,
              "TotalPrice": 4697.27,
              "TotalPriceEUR": 4697.27,
              "TotalPriceExclTax": 0.0
            }
          ]
        },
        "output": {
          "Offers": [
            {
              "Price": 2977.6,
              "Currency": "EUR",
              "Link": null,
              "Tickettyp": 1,
              "Flightindex": 0
            },
            {
              "Price": 4697.27,
              "Currency": "EUR",
              "Link": null,
              "Tickettyp": 1,
              "Flightindex": 1
            }
          ]
        }
      }
    ],
    "identifier": 52759139
  },
  {
    "context": [
      "I want to just output the correct result with the key and value through the jq option.",
      "Example: I input Key:value is key3:value3. My desire:\r\n\r\n    {\r\n          \"AvailabilityZone\": \"ap-northeast-1a\",\r\n          \"Tags\": [\r\n            {\r\n              \"Value\": \"value3\",\r\n              \"Key\": \"key3\"\r\n            },\r\n            {\r\n              \"Value\": \"value4\",\r\n              \"Key\": \"key4\"\r\n            }\r\n          ],\r\n    }",
      "Use select to filter the array under Tags:\r\n\r\n    jq '[].Tags | select((.[].Key == \"key3\") and (.[].Value=\"value3\"))  ' < file.json",
      "Together with reading the key and value from the stdin:\r\n\r\n    echo key3 value3 | (\r\n        read key value\r\n        k=$key v=$value jq \"[].Tags\r\n            | select((.[].Key == env.k) and (.[].Value=env.v))\r\n        \" < file.json)"
    ],
    "utterance": "Return the object where one of its Tags has Key equal to key3 and Value equal to value3.",
    "expressions": [
      ".[] | select(.Tags[] | (.Key == \"key3\" and .Value == \"value3\"))"
    ],
    "data": [
      {
        "input": [
          {
            "AvailabilityZone": "ap-northeast-1a",
            "Tags": [
              {
                "Value": "value1",
                "Key": "key1"
              },
              {
                "Value": "value2",
                "Key": "key2"
              }
            ]
          },
          {
            "AvailabilityZone": "ap-northeast-1a",
            "Tags": [
              {
                "Value": "value3",
                "Key": "key3"
              },
              {
                "Value": "value4",
                "Key": "key4"
              }
            ]
          }
        ],
        "output": {
          "AvailabilityZone": "ap-northeast-1a",
          "Tags": [
            {
              "Value": "value3",
              "Key": "key3"
            },
            {
              "Value": "value4",
              "Key": "key4"
            }
          ]
        }
      }
    ],
    "identifier": 52754571
  },
  {
    "context": [
      "I wanna create a key with Test name. My desired result:",
      "\"Test\": {\n      \"HealthCheckPath\": \"/\",\n      \"HealthCheckIntervalSeconds\": 30\n}",
      "Run below to get desired output:  ",
      "jq '{ \"Test\" : .}' file.json"
    ],
    "utterance": "Wrap the entire object under a new key named Test.",
    "expressions": [
      "{ \"Test\": . }"
    ],
    "data": [
      {
        "input": {
          "HealthCheckPath": "/",
          "HealthCheckIntervalSeconds": 30
        },
        "output": {
          "Test": {
            "HealthCheckPath": "/",
            "HealthCheckIntervalSeconds": 30
          }
        }
      }
    ],
    "identifier": 52772515
  },
  {
    "context": [
      "So I would like some advice on how id get \"bar\" from the JSON",
      "Use the `fromjson` construct to restore the strings as JSON texts. So, given the content below",
      "jq '.\"message\"|fromjson|.bar' file",
      "\"less interesting data\""
    ],
    "utterance": "Extract the value of the field 'bar' from a string-encoded JSON object inside the 'message' property.",
    "expressions": [
      ".message | fromjson | .bar",
      ".message | fromjson.bar"
    ],
    "data": [
      {
        "input": {
          "message": "{ \"foo\": \"42\", \"bar\": \"less interesting data\" }"
        },
        "output": "less interesting data"
      }
    ],
    "identifier": 52778332
  },
  {
    "context": [
      "Trying to filter json based on `addrtype` and printing `addr` if `addrtype` is `ipv4` and `vendor` if `addrtype` is `mac`.",
      "Desired Result:\r\n\r\n    192.168.1.235 - Nest Labs\r\n    192.168.1.236 - Nest Labs\r\n    192.168.1.238 - \r\n    192.168.1.254 - ",
      "This produces the desired result:\r\n\r\n    jq -sr '.[] | \"\\(.[0].addr) - \\(.[1].vendor//\"\")\"' file"
    ],
    "utterance": "For each array, print the addr where addrtype is ipv4, followed by a dash and the vendor value where addrtype is mac if present, otherwise just a dash.",
    "expressions": [
      ".[] | \"\\(.[0].addr) - \\(.[1].vendor//\"\")\""
    ],
    "data": [
      {
        "input": [
          [
            {
              "addr": "192.168.1.235",
              "addrtype": "ipv4"
            },
            {
              "addr": "18:B4:30:8D:AE:BA",
              "addrtype": "mac",
              "vendor": "Nest Labs"
            }
          ],
          [
            {
              "addr": "192.168.1.236",
              "addrtype": "ipv4"
            },
            {
              "addr": "18:B4:30:8D:B6:18",
              "addrtype": "mac",
              "vendor": "Nest Labs"
            }
          ],
          [
            {
              "addr": "192.168.1.238",
              "addrtype": "ipv4"
            },
            {
              "addr": "0C:EA:C9:AF:4F:72",
              "addrtype": "mac"
            }
          ],
          [
            {
              "addr": "192.168.1.254",
              "addrtype": "ipv4"
            },
            {
              "addr": "0C:EA:C9:AF:4F:70",
              "addrtype": "mac"
            }
          ]
        ],
        "output": [
          "192.168.1.235 - Nest Labs",
          "192.168.1.236 - Nest Labs",
          "192.168.1.238 - ",
          "192.168.1.254 - "
        ]
      }
    ],
    "identifier": 52840069
  },
  {
    "context": [
      "I want to print :\n\n    Sunrise is expected at 5:12:13 AM and sunset at 6:26:23 PM.",
      "curl -X GET 'https://api.sunrise-sunset.org/json?lat=36.7201600&lng=-4.4203400' | \\\n  jq -r '.results | \"Sunrise is expected at \\(.sunrise) and sunset is expected at \\(.sunset)\"'"
    ],
    "utterance": "Print a sentence that includes both the sunrise and sunset times in the format: 'Sunrise is expected at <sunrise> and sunset is expected at <sunset>'.",
    "expressions": [
      ".results | \"Sunrise is expected at \\(.sunrise) and sunset is expected at \\(.sunset)\""
    ],
    "data": [
      {
        "input": {
          "results": {
            "sunrise": "5:12:13 AM",
            "sunset": "6:26:23 PM"
          }
        },
        "output": "Sunrise is expected at 5:12:13 AM and sunset is expected at 6:26:23 PM"
      }
    ],
    "identifier": 52855368
  },
  {
    "context": [
      "I am struggling with JQ trying to  select array of strings values from an input json using specific keys to select. The \"key\":[\"string1\",... , \"stringn\"] can be embeded \"somewhere\" at any depth in the json. I only know the key values of the arrays.",
      "In this exemple, I would like to select the \"key4\" and \"key11\" arrays and get them in a result json with the corresponding keys.",
      "my expected output for this sample would be :\n\n{\n    \"key4\": [\"anotherValue4341\", \"anotherValue4342\"],\n    \"key11\": [\"lastvalue111\", \"lastvalue112\", \"lastvalue113\"]\n}",
      "def getKeyValue($key):\n  .. | objects | select(has($key)) | {($key): .[$key]};",
      "[.dict[] as $k | getKeyValue($k)] | add",
      ".source as $source \n| [ \n  .dict[] | . as $key \n  | $source | .. \n  | select(.[$key]?) \n  | { ($key): .[$key]? } \n] | add"
    ],
    "utterance": "Extract all arrays found at any depth whose key matches any key in the top-level dict array and return an object with those keys and values.",
    "expressions": [
      "[.dict[] as $k | .. | objects | select(has($k)) | {($k): .[$k]}] | add",
      ".source as $source | [ .dict[] as $key | $source | .. | select(.[$key]?) | { ($key): .[$key]? } ] | add"
    ],
    "data": [
      {
        "input": {
          "dict": [
            "key4",
            "key11"
          ],
          "source": {
            "key0": {
              "key1": "valueA",
              "key2": 123456,
              "key3": [
                {
                  "key4": [
                    "anotherValue4341",
                    "anotherValue4342"
                  ],
                  "key5": [
                    {
                      "someKey351": "someValue351"
                    },
                    {
                      "someKey352": "someValue352"
                    }
                  ],
                  "key6": 999
                },
                {
                  "key7": "anotherValue342",
                  "key8": "anotherValue352",
                  "key9": 666
                }
              ],
              "key10": {
                "key11": [
                  "lastvalue111",
                  "lastvalue112",
                  "lastvalue113"
                ]
              }
            }
          }
        },
        "output": {
          "key4": [
            "anotherValue4341",
            "anotherValue4342"
          ],
          "key11": [
            "lastvalue111",
            "lastvalue112",
            "lastvalue113"
          ]
        }
      }
    ],
    "identifier": 52832938
  },
  {
    "context": [
      "mosquitto_sub -h 192.168.178.20 -t tele/POW/SENSOR/# | jq '.ENERGY|.Power'",
      "mosquitto_sub -h 192.168.178.20 -t tele/POW/SENSOR/# | jq '.ENERGY|.Power' > output.log",
      "From the jq manual:\n\n    --unbuffered\n    \n    Flush the output after each JSON object is printed \n    (useful if you\u2019re piping a slow data source into\n    jq and piping jq\u2019s output elsewhere)."
    ],
    "utterance": "Write only the value of the 'Power' key from each received object to a file, ensuring each value is output as soon as it is received.",
    "expressions": [
      "mosquitto_sub -h 192.168.178.20 -t tele/POW/SENSOR/# | jq --unbuffered '.ENERGY|.Power' > output.log"
    ],
    "identifier": 52889146
  },
  {
    "context": [
      "I want to write jq json parsing tool to modify \"name:harry potter\" from state \"sold\" to \"returned\"",
      ".amazon.items |= map(if .name == \"harry potter\" and .state == \"sold\"\n           then .state = \"returned\" else . end)",
      "jq '.amazon.items |= map(select(.name==\"harry potter\").state=\"returned\")' file"
    ],
    "utterance": "Change the state field to \"returned\" for items with name equal to \"harry potter\" and state equal to \"sold\".",
    "expressions": [
      ".amazon.items |= map(if .name == \"harry potter\" and .state == \"sold\" then .state = \"returned\" else . end)",
      ".amazon.items |= map(select(.name==\"harry potter\").state=\"returned\")"
    ],
    "data": [
      {
        "input": {
          "amazon": {
            "items": [
              {
                "name": "harry potter",
                "state": "sold"
              },
              {
                "name": "adidas shoes",
                "state": "in inventory"
              },
              {
                "name": "watch",
                "state": "returned"
              }
            ]
          }
        },
        "output": {
          "amazon": {
            "items": [
              {
                "name": "harry potter",
                "state": "returned"
              },
              {
                "name": "adidas shoes",
                "state": "in inventory"
              },
              {
                "name": "watch",
                "state": "returned"
              }
            ]
          }
        }
      }
    ],
    "identifier": 52884819
  },
  {
    "context": [
      "echo \"${PRESET_ARR}\" | jq -r '.[] | (.resolution, .bitrate, .framerate)' |",
      "done < <(jq -r '.[] | (.resolution, .bitrate, .framerate)' <<< \"${PRESET_ARR}\")"
    ],
    "utterance": "Extract the resolution, bitrate, and framerate fields from each object in an array passed as a string variable.",
    "expressions": [
      ".[] | (.resolution, .bitrate, .framerate)"
    ],
    "data": [
      {
        "input": [
          {
            "resolution": "2160*2160",
            "bitrate": "60M",
            "framerate": 60
          },
          {
            "resolution": "1350*1350",
            "bitrate": "30M",
            "framerate": 60
          }
        ],
        "output": [
          "2160*2160",
          "60M",
          60,
          "1350*1350",
          "30M",
          60
        ]
      }
    ],
    "identifier": 52896898
  },
  {
    "context": [
      "a.json\n   \n\n    {\"a\": 1}\n\nb.json\n\n    {\"b\": 1}\n\nDesired outcome\n\n    {\"a\": 1, \"b\": 1}",
      "Try:\n\n    jq -s 'add' a.json b.json\n\nResult:\n\n    {\n      \"a\": 1,\n      \"b\": 1\n    }",
      "In any case, to accomplish the task economically, use -n in conjunction with `inputs` as follows:\n  \n    reduce inputs as $i ({}; . + $i)"
    ],
    "utterance": "Combine the key-value pairs from two separate files where one has {\"a\": 1} and the other has {\"b\": 1} into a single object with both keys and values.",
    "expressions": [
      "jq -s 'add' a.json b.json",
      "jq -n 'reduce inputs as $i ({}; . + $i)' a.json b.json"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1
          },
          {
            "b": 1
          }
        ],
        "output": {
          "a": 1,
          "b": 1
        }
      }
    ],
    "identifier": 52889783
  },
  {
    "context": [
      "How do I filter out the sub-objects that do not have a `nodes` key, eg: `172.17.0.16`?",
      "Your original doesn't do any filtering, add it:",
      ".node.nodes[] | select(.nodes != null).key"
    ],
    "utterance": "List the key fields for all elements in .node.nodes[] that contain a nodes subkey.",
    "expressions": [
      ".node.nodes[] | select(.nodes != null).key"
    ],
    "data": [
      {
        "input": {
          "node": {
            "nodes": [
              {
                "key": "/galera/mariadb_galera/172.17.0.8",
                "dir": true,
                "nodes": [
                  {
                    "key": "/galera/mariadb_galera/172.17.0.8/ipaddress",
                    "value": "172.17.0.8",
                    "modifiedIndex": 9,
                    "createdIndex": 9
                  },
                  {
                    "key": "/galera/mariadb_galera/172.17.0.8/wsrep_local_state_comment",
                    "value": "Synced",
                    "expiration": "2018-10-17T21:24:48.94524993Z",
                    "ttl": 2,
                    "modifiedIndex": 52905,
                    "createdIndex": 52905
                  },
                  {
                    "key": "/galera/mariadb_galera/172.17.0.8/seqno",
                    "value": "1367",
                    "expiration": "2018-10-17T21:24:49.213778533Z",
                    "ttl": 2,
                    "modifiedIndex": 52907,
                    "createdIndex": 52907
                  }
                ],
                "modifiedIndex": 9,
                "createdIndex": 9
              },
              {
                "key": "/galera/mariadb_galera/172.17.0.16",
                "dir": true,
                "modifiedIndex": 48,
                "createdIndex": 48
              },
              {
                "key": "/galera/mariadb_galera/172.17.0.17",
                "dir": true,
                "modifiedIndex": 111,
                "createdIndex": 111
              },
              {
                "key": "/galera/mariadb_galera/172.17.0.11",
                "dir": true,
                "nodes": [
                  {
                    "key": "/galera/mariadb_galera/172.17.0.11/wsrep_local_state_comment",
                    "value": "Synced",
                    "expiration": "2018-10-17T21:24:55.990291814Z",
                    "ttl": 9,
                    "modifiedIndex": 52909,
                    "createdIndex": 52909
                  },
                  {
                    "key": "/galera/mariadb_galera/172.17.0.11/seqno",
                    "value": "1367",
                    "expiration": "2018-10-17T21:24:56.113268568Z",
                    "ttl": 9,
                    "modifiedIndex": 52910,
                    "createdIndex": 52910
                  }
                ],
                "modifiedIndex": 50749,
                "createdIndex": 50749
              },
              {
                "key": "/galera/mariadb_galera/172.17.0.14",
                "dir": true,
                "nodes": [
                  {
                    "key": "/galera/mariadb_galera/172.17.0.14/wsrep_local_state_comment",
                    "value": "Synced",
                    "expiration": "2018-10-17T21:24:49.029444262Z",
                    "ttl": 2,
                    "modifiedIndex": 52906,
                    "createdIndex": 52906
                  },
                  {
                    "key": "/galera/mariadb_galera/172.17.0.14/seqno",
                    "value": "1367",
                    "expiration": "2018-10-17T21:24:49.358067474Z",
                    "ttl": 2,
                    "modifiedIndex": 52908,
                    "createdIndex": 52908
                  }
                ],
                "modifiedIndex": 52076,
                "createdIndex": 52076
              }
            ]
          }
        },
        "output": [
          "/galera/mariadb_galera/172.17.0.8",
          "/galera/mariadb_galera/172.17.0.11",
          "/galera/mariadb_galera/172.17.0.14"
        ]
      }
    ],
    "identifier": 52864063
  },
  {
    "context": [
      "I still can't get multivalued fields to get concatenated into a single field with a semicolon separator without getting super kludgy.",
      "But I'm not able to convert the 3 subjects that get returned with this to a 3 item array that I can join -- I always get 3 separate strings.",
      "I can accomplish what I need by doing  jq '(.element_texts[] | (select(.element.name==\"Title\") | .text), (select(.element.name==\"Date\") | .text)), ([.element_texts[] | (select(.element.name==\"Subject\") | .text)] | join(\";\"))'",
      "the following filter produces the output as shown:\n\n    .element_texts\n    | [(.[]\n       | ((select(.element.name==\"Title\"),\n          (select(.element.name==\"Date\")))\n       | .text)),\n       (map(select(.element.name==\"Subject\") | .text) \n        | join(\";\") ) ]\n    | @tsv"
    ],
    "utterance": "Combine the Title, Date, and all Subject values (joined with semicolons) from element_texts into a tab-delimited record.",
    "expressions": [
      ".element_texts\n| [(.[]\n   | ((select(.element.name==\"Title\"),\n      (select(.element.name==\"Date\")))\n   | .text)),\n   (map(select(.element.name==\"Subject\") | .text)\n    | join(\";\") ) ]\n| @tsv"
    ],
    "data": [
      {
        "input": {
          "element_texts": [
            {
              "element": {
                "name": "Title"
              },
              "text": "Esther Pohl Lovejoy, M.D."
            },
            {
              "element": {
                "name": "Date"
              },
              "text": "1894"
            },
            {
              "element": {
                "name": "Subject"
              },
              "text": "Lovejoy, Esther Clayson Pohl, M.D., 1869-1967\r\n"
            },
            {
              "element": {
                "name": "Subject"
              },
              "text": "Physicians, Women"
            },
            {
              "element": {
                "name": "Subject"
              },
              "text": "Portraits"
            }
          ]
        },
        "output": "Esther Pohl Lovejoy, M.D.\t1894\tLovejoy, Esther Clayson Pohl, M.D., 1869-1967\r\n;Physicians, Women;Portraits"
      }
    ],
    "identifier": 52900364
  },
  {
    "context": [
      "I have input data like:",
      "{ \"id\": \"person1\", \"name\": \"wilma\", \"age\": \"quite old\"}",
      "{ \"id\": \"person2\", \"name\": \"fred\"}",
      "{ \"id\": \"person1\", \"name\": \"betty\", \"x\": \"extra\"}",
      "I want output like this:",
      "{",
      "   \"person1\": { \"name\": \"betty\", \"age\": \"quite old\", \"x\": \"extra\" },",
      "   \"person2\": { \"name\": \"fred\" }",
      "}",
      "Ah! I've got it! Or I've got one solution - please post if there's a better way.",
      "jq -s '[group_by(.id)[]| add | { (.id) : . } ]|add' <data",
      "EDIT",
      "This is uglier but produces the same result and is ~24% faster on a 9MB dataset.",
      "jq -s 'reduce [.[]|{ (.id) : . }][] as $item ({}; . * $item )' <data"
    ],
    "utterance": "Combine objects sharing the same id into a single object keyed by id, merging their properties so later values overwrite earlier ones.",
    "expressions": [
      "[group_by(.id)[]| add | { (.id) : . } ]|add",
      "reduce [.[]|{ (.id) : . }][] as $item ({}; . * $item )"
    ],
    "data": [
      {
        "input": [
          {
            "id": "person1",
            "name": "wilma",
            "age": "quite old"
          },
          {
            "id": "person2",
            "name": "fred"
          },
          {
            "id": "person1",
            "name": "betty",
            "x": "extra"
          }
        ],
        "output": {
          "person1": {
            "name": "betty",
            "age": "quite old",
            "x": "extra"
          },
          "person2": {
            "name": "fred"
          }
        }
      }
    ],
    "identifier": 52927897
  },
  {
    "context": [
      "i'm trying to convert a json to a tab formatted data:",
      "{ \"level\":\"INFO\", \"logger\":\"db\", \"msg\":\"connection successful\" }",
      "{ \"level\":\"INFO\", \"logger\":\"server\", \"msg\":\"server started\" }",
      "to something like this:",
      "INFO   db       connection successful",
      "I've tried this `jq -r ' . | to_entries[] | \"\\(.value)\"'`, but this prints each value on a separate line.",
      "Assuming the keys are always in the same order, you could get away with:",
      "jq -r '[.[]]|@tsv'",
      "In any case, it would be preferable to use `@tsv`."
    ],
    "utterance": "Print each record's level, logger, and msg fields as space-separated values on one line, one record per line.",
    "expressions": [
      "[.[]] | @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "level": "INFO",
            "logger": "db",
            "msg": "connection successful"
          },
          {
            "level": "INFO",
            "logger": "server",
            "msg": "server started"
          },
          {
            "level": "INFO",
            "logger": "server",
            "msg": "listening on port :4000"
          },
          {
            "level": "INFO",
            "logger": "server",
            "msg": "stopping s ervices ..."
          },
          {
            "level": "INFO",
            "logger": "server",
            "msg": "exiting..."
          }
        ],
        "output": "INFO\tdb\tconnection successful\nINFO\tserver\tserver started\nINFO\tserver\tlistening on port :4000\nINFO\tserver\tstopping s ervices ...\nINFO\tserver\texiting..."
      }
    ],
    "identifier": 52928296
  },
  {
    "context": [
      "which is filtered by jq in this way\n\n    ALL_VOLUME_NAMES=$(jq '.volumes[].name' <<< \"$ALL_VOLUMES_HTTP\")",
      "the output of `ALL_VOLUME_NAMES` is formatted like this\n\n    \"volumeName1\"\n    \"volumeName2\"",
      "I already tried to put brackets about the jq (`jq '[.volumes[].name'`) but it is displayed completely wrong too",
      "It is possible to concat the information to one string. This results in this code:\n\n    ALL_VOLUMES_HTTP=$(curl --silent --write-out \"HTTPSTATUS:%{http_code}\" -H \"Authorization: Bearer $1\" https://api.hetzner.cloud/v1/volumes)\n    ALL_VOLUME_NAMES=$(echo $ALL_VOLUMES_HTTP | jq -r '.volumes[].name')\n    \n    VALUES=\"\"\n    for i in $ALL_VOLUME_NAMES; do\n            VALUES=\"$VALUES $(jq -r '.volumes[]|select(.name==\"'$i'\")|.id' <<< \"$ALL_VOLUMES_HTTP\") $i\"\n    done"
    ],
    "utterance": "Extract all name fields from all objects in the volumes array as separate lines of plain text.",
    "expressions": [
      ".volumes[].name",
      ".volumes[].name | @text",
      "-r '.volumes[].name'"
    ],
    "data": [
      {
        "input": {
          "volumes": [
            {
              "id": 123,
              "name": "volumeName1"
            },
            {
              "id": 456,
              "name": "volumeName2"
            }
          ]
        },
        "output": [
          "volumeName1",
          "volumeName2"
        ]
      }
    ],
    "identifier": 52917327
  },
  {
    "context": [
      "I am looking to create a JSON file from scratch that looks like this:\r\n\r\n    {\r\n       \"Key1\": {\r\n          \"SubKey1\": \"Value1\",\r\n          \"SubKey2\": \"Value2\"\r\n        }\r\n    }\r\n",
      "I have the following variables in my bash script:\r\n\r\n    $key1\r\n    $subkey1\r\n    $subkey2\r\n    $value1\r\n    $value2",
      "jq -n --arg key1 \"$key1\" --arg subkey1 \"$subkey1\" --arg subkey2 \"$subkey2\" --arg value1 \"$value1\" --arg value2 \"$value2\" '\r\n{\r\n   ($key1): {\r\n       ($subkey1): $value1,\r\n       ($subkey2): $value2\r\n    }\r\n}\r\n'",
      ".[$key1] = (.[$subkey1]=$value1 | .[$subkey2]=$value2)"
    ],
    "utterance": "Create an object with a top-level key from a variable, whose value is an object with two keys and values taken from other variables.",
    "expressions": [
      "{ ($key1): { ($subkey1): $value1, ($subkey2): $value2 } }",
      ".[$key1] = (.[$subkey1]=$value1 | .[$subkey2]=$value2)"
    ],
    "data": [
      {
        "input": {},
        "output": {
          "Key1": {
            "SubKey1": "Value1",
            "SubKey2": "Value2"
          }
        }
      }
    ],
    "identifier": 52935977
  },
  {
    "context": [
      "but how do I also return the `Name` from the output",
      "This will return the `Name` and `Type` attributes of each entry.",
      "aws route53 .... | jq '.ResourceRecordSets[] | [.Name, .Type]'"
    ],
    "utterance": "Return both the Name and Type fields for all records.",
    "expressions": [
      ".ResourceRecordSets[] | [.Name, .Type]"
    ],
    "data": [
      {
        "input": {
          "ResourceRecordSets": [
            {
              "ResourceRecords": [
                {
                  "Value": "123.123.123.123"
                }
              ],
              "TTL": 21600,
              "Type": "A",
              "Name": "www.domain.tld."
            },
            {
              "ResourceRecords": [
                {
                  "Value": "cname.target."
                }
              ],
              "TTL": 21600,
              "Type": "CNAME",
              "Name": "alias.domain.tld."
            }
          ]
        },
        "output": [
          [
            "www.domain.tld.",
            "A"
          ],
          [
            "alias.domain.tld.",
            "CNAME"
          ]
        ]
      }
    ],
    "identifier": 52953911
  },
  {
    "context": [
      "I\u2019d like to display all `prices` that have more than one costs.",
      ".result.spaces[].priceschema.prices[]\n| {price: .}\n| select((.price.costs? | length) > 1)"
    ],
    "utterance": "Display all price objects where the costs array contains more than one entry.",
    "expressions": [
      ".result.spaces[].priceschema.prices[] | {price: .} | select((.price.costs? | length) > 1)"
    ],
    "data": [
      {
        "input": {
          "result": {
            "spaces": [
              {
                "priceschema": {
                  "prices": [
                    {
                      "costs": [
                        {
                          "amount": "3"
                        }
                      ]
                    }
                  ]
                }
              }
            ]
          }
        }
      }
    ],
    "identifier": 52978489
  },
  {
    "context": [
      "I need all the values for keys which exist in both files, copied from *source.json* to *target.json*, considering all the levels.",
      "Keys in *target JSON* must not be deleted and new keys should not be created.",
      "Only \"key1\" and \"key3\" should be copied.",
      "One approach you could take is get all the paths to all scalar values for each input and take the set intersections. Then copy values from source to target from those paths.",
      "Then to do the update:\n\n    $ jq --argfile s source.json '\n    reduce ([paths(scalars)] | set_intersect([$s | paths(scalars)])[]) as $p (.;\n        setpath($p; $s | getpath($p))\n    )\n    ' target.json",
      "The following provides a solution to the revised question, which is actually about \"paths\" rather than \"keys\".\n\n    ([$target|paths(scalars)] | unique) as $paths\n    | reduce ($source|paths(scalars)) as $p\n        ($target;\n         if $paths | bsearch($p) > -1 \n         then setpath($p; $source|getpath($p))\n         else . end)\n"
    ],
    "utterance": "Update the values in the target file with those from the source file for all keys that exist in both files at any nested level, without altering the target's structure or adding new keys.",
    "expressions": [
      "($target | keys) as $t\n| reduce ($source|paths(scalars)) as $p\n    ($target;\n     if $t|bsearch($p[-1]) > -1 \n     then setpath($p; $source|getpath($p))\n     else . end)",
      "([$target|paths(scalars)] | unique) as $paths\n| reduce ($source|paths(scalars)) as $p\n    ($target;\n     if $paths | bsearch($p) > -1 \n     then setpath($p; $source|getpath($p))\n     else . end)",
      "reduce ([paths(scalars)] | set_intersect([$s | paths(scalars)])[]) as $p (.;\n    setpath($p; $s | getpath($p))\n)"
    ],
    "data": [
      {
        "input": {
          "source": {
            "general": {
              "level1": {
                "key1": "x-x-x-x-x-x-x-x",
                "key3": "z-z-z-z-z-z-z-z",
                "key4": "w-w-w-w-w-w-w-w"
              },
              "another": {
                "key": "123456",
                "comments": {
                  "one": "111",
                  "other": "222"
                }
              }
            },
            "title": "The best"
          },
          "target": {
            "general": {
              "level1": {
                "key1": "xxxxxxxx",
                "key2": "yyyyyyyy",
                "key3": "zzzzzzzz"
              },
              "onemore": {
                "kkeeyy": "0000000"
              }
            },
            "specific": {
              "stuff": "test"
            },
            "title": {
              "one": "one title",
              "other": "other title"
            }
          }
        },
        "output": {
          "general": {
            "level1": {
              "key1": "x-x-x-x-x-x-x-x",
              "key2": "yyyyyyyy",
              "key3": "z-z-z-z-z-z-z-z"
            },
            "onemore": {
              "kkeeyy": "0000000"
            }
          },
          "specific": {
            "stuff": "test"
          },
          "title": {
            "one": "one title",
            "other": "other title"
          }
        }
      }
    ],
    "identifier": 52853997
  },
  {
    "context": [
      "Trying to pass a bash shell variable into a jq filter",
      "Bash command trying to execute:",
      "servername='server1'",
      "jq --arg servername \"$servername\" '.$servername .port'",
      "But getting an error",
      "jq: error: syntax error, unexpected '$' (Unix shell quoting issues?) at <top-level>, line 1:",
      "But direct substitution works",
      "jq '.server1 .port'",
      "You could write:",
      ".[$servername] | .port",
      "or simply:",
      ".[$servername].port"
    ],
    "utterance": "Access the 'port' property of the object named by the shell variable 'servername'.",
    "expressions": [
      ".[$servername] | .port",
      ".[$servername].port"
    ],
    "data": [
      {
        "input": {
          "server1": {
            "port": 3333,
            "name": "foo",
            "timesincelast": 248054
          },
          "server2": {
            "port": 4444,
            "name": "bar",
            "timesincelast": 248054
          }
        },
        "output": 3333
      }
    ],
    "identifier": 52959216
  },
  {
    "context": [
      "I have json file of this structure:",
      "{\n\t\"key\": [\n\t\t{\n\t\t\t\"key1\": 1,\n\t\t\t\"key2\": 1,\n\t\t\t\"key3\": {\n\t\t\t\t\"1\": 1,\n\t\t\t\t\"2\": 2,\n\t\t\t\t\"3\": 3,\n\t\t\t\t\"4\": 4\n\t\t\t}\n\t\t},\n\t\t{\n\t\t\t\"key1\": 2,\n\t\t\t\"key2\": 2,\n\t\t\t\"key3\": {\n    \t\t\t\t\"2\": 2\n\t\t\t}\n\t\t}\n\t\t...\n\t],\n\t...\n}",
      "I was using this jq call to convert my json to csv:\n\n    bin\\jq-win64 \".key[] | [.key1, .key2, .key3.\\\"1\\\", .key3.\\\"2\\\", .key3.\\\"3\\\", .key3.\\\"4\\\" ] | tostring] | join(\\\";\\\")\" source.json > output.tmp",
      "In some cases `key3` might not be full 4 element object (4 is the max with keys 1/2/3/4, just like in example). I have a problem with those missing subkeys, because jq returns \"null\" and that does not work well with CSV evaluation in excel or calc. Is there a way to force empty string or numeric 0 as output in such case?",
      "You could tweak your pipeline by adding\n\n    map(. // 0)\n\nright after forming the array.",
      "If you want to preserve `false`, then you would have to add\n\n    map(if . == null then 0 else . end)\n\ninstead."
    ],
    "utterance": "Return 0 instead of null when specific subkeys are missing in nested objects during a query for multiple keys.",
    "expressions": [
      ".key[] | [.key1, .key2, .key3.\"1\", .key3.\"2\", .key3.\"3\", .key3.\"4\"] | map(. // 0) | tostring | join(\";\")",
      ".key[] | [.key1, .key2, .key3.\"1\", .key3.\"2\", .key3.\"3\", .key3.\"4\"] | map(if . == null then 0 else . end) | tostring | join(\";\")"
    ],
    "data": [
      {
        "input": {
          "key": [
            {
              "key1": 1,
              "key2": 1,
              "key3": {
                "1": 1,
                "2": 2,
                "3": 3,
                "4": 4
              }
            },
            {
              "key1": 2,
              "key2": 2,
              "key3": {
                "2": 2
              }
            }
          ]
        },
        "output": [
          "1;1;1;2;3;4",
          "2;2;0;2;0;0"
        ]
      }
    ],
    "identifier": 52925518
  },
  {
    "context": [
      "My objective is to set module and version from args passed in jq command",
      "jq --arg module \"themodule\" --arg version \"3.0\" '{.require.($module):$version}'",
      "jq -n --arg m themodule --arg version \"3.0\" '\n  {require: { ($m): $version} }'",
      "The trick here is to enclose the expression specifying the key-name in parentheses."
    ],
    "utterance": "Create a file containing an object with a 'require' key, whose value is an object with a dynamic key and value set from command arguments.",
    "expressions": [
      "jq -n --arg m \"themodule\" --arg version \"3.0\" '{require: { ($m): $version} }'"
    ],
    "data": [
      {
        "input": null,
        "output": {
          "require": {
            "themodule": "3.0"
          }
        }
      }
    ],
    "identifier": 52992608
  },
  {
    "context": [
      "I want to add one more key value pair. The key is also a variable and the value too. bundle_release=\"2019.78\" and value= {\"release\":\"2018.1006\",\"kernel\":\"2.6.32-754.3.5.el6.x86_64\",\"os\":\"6.10\",\"current\":true} Now I want the bundle_release as key and value as its value, So the new entry would be \"2018.1006\": {\"release\":\"2018.1006\",\"kernel\":\"2.6.32-754.3.5.el6.x86_64\",\"os\":\"6.10\",\"current\":true}",
      "jq --arg b \"$bundle_release\" --argjson v \"$value\"  '. + {($b): $v}' <<< \"$version6json\""
    ],
    "utterance": "Add a new key-value pair where the key is the value of the shell variable bundle_release and the value is the parsed object from the shell variable value.",
    "expressions": [
      ". + {($b): $v}"
    ],
    "data": [
      {
        "input": {
          "20007.098": {
            "os_version": "6.9",
            "kernel": "2.6.32-696",
            "sfdc-release": "2017.08"
          },
          "200907.09678": {
            "os_version": "6.9",
            "kernel": "2.6.32-696",
            "sfdc-release": "201.7909"
          },
          "206727.1078": {
            "os_version": "6.9",
            "kernel": "2.6.32-696.10.2.el6.x86_64",
            "sfdc-release": "20097.109"
          }
        },
        "output": {
          "20007.098": {
            "os_version": "6.9",
            "kernel": "2.6.32-696",
            "sfdc-release": "2017.08"
          },
          "200907.09678": {
            "os_version": "6.9",
            "kernel": "2.6.32-696",
            "sfdc-release": "201.7909"
          },
          "206727.1078": {
            "os_version": "6.9",
            "kernel": "2.6.32-696.10.2.el6.x86_64",
            "sfdc-release": "20097.109"
          },
          "2019.78": {
            "release": "2018.1006",
            "kernel": "2.6.32-754.3.5.el6.x86_64",
            "os": "6.10",
            "current": true
          }
        }
      }
    ],
    "identifier": 52964732
  },
  {
    "context": [
      "How do i get the following output using jq filter \r\n\r\nApplication : webserver\r\n",
      ".Tags[]\r\n    | select(.Key == \"Application\")\r\n    | \"\\(.Key) : \\(.Value)\""
    ],
    "utterance": "Output the key and value for the tag where Key is Application in the format 'Application : webserver'.",
    "expressions": [
      ".Tags[] | select(.Key == \"Application\") | \"\\(.Key) : \\(.Value)\""
    ],
    "data": [
      {
        "input": {
          "Tags": [
            {
              "ResourceType": "instance",
              "ResourceId": "i-8dh7435490fjksfd",
              "Value": "production",
              "Key": "Environment"
            },
            {
              "ResourceType": "instance",
              "ResourceId": "i-8dh7435490fjksfd",
              "Value": "webserver",
              "Key": "Application"
            }
          ]
        },
        "output": "Application : webserver"
      }
    ],
    "identifier": 52995690
  },
  {
    "context": [
      "I\u2019m trying to replace the value of a key in my original JSON with the value of an object with the corresponding key in another document.",
      "The goal is to create 3 new files, where the original keys have been replaced with the value of a, b and c in each file.",
      "Desired result when looking against \"a\":",
      "jq --arg k a --argfile file2 file2.json 'with_entries(.key |= $file2[.][$k])' file1.json > out_a.json",
      "How do I handle the scenario where the key from File 1 might not exist in File 2, resulting in the \"Cannot use null (null) as object key\"?",
      "with_entries(.key |= (if $file2[.]|has($k) then $file2[.][$k]  else . end))"
    ],
    "utterance": "Replace each top-level key with the value at property 'a', 'b', or 'c' from a second object keyed by the original key; skip keys missing in the second object.",
    "expressions": [
      "with_entries(.key |= $file2[.][$k])",
      "with_entries(.key |= (if $file2[.]|has($k) then $file2[.][$k] else . end))"
    ],
    "data": [
      {
        "input": {
          "file1": {
            "-KaM0otlgWxXniYiacFe": {
              "-LNxx1IiX6oYTxJ4IXx2": true
            },
            "-KlJTvbfonIMI_-YfS5R": {
              "-LNxx1IbaB-yrZ623hrX": true
            }
          },
          "file2": {
            "-KaM0otlgWxXniYiacFe": {
              "a": "-L-b__nH9PlMcz0stDDE",
              "b": "-L7ZNKSZy570TlrQUzHM",
              "c": "-Kaae3MsQUyViCKPs8Iv"
            },
            "-KlJTvbfonIMI_-YfS5R": {
              "a": "-LAlXKfUUTdYDeCZH-u-",
              "b": "-L7ZNKSTnob7w0HXjHr6",
              "c": "-KYYicPD7VA9DEF_rus3"
            }
          }
        },
        "output": {
          "-L-b__nH9PlMcz0stDDE": {
            "-LNxx1IiX6oYTxJ4IXx2": true
          },
          "-LAlXKfUUTdYDeCZH-u-": {
            "-LNxx1IbaB-yrZ623hrX": true
          }
        }
      }
    ],
    "identifier": 52991305
  },
  {
    "context": [
      "I need to get the \"Id\" column value. Since in this json there are 3 records, record with maximum value id would be returned. So after processing of below json I should get 170.",
      "The id's are stored in an array under the key `value`. `.value[].id` lists the ids, if you put them into an array, you can call `max` on it:",
      "jq '[.value[].id] | max' < file.json"
    ],
    "utterance": "Get the highest id value from the records under the value key.",
    "expressions": [
      "[.value[].id] | max"
    ],
    "data": [
      {
        "input": {
          "count": 3,
          "value": [
            {
              "properties": {},
              "tags": [],
              "validationResults": [],
              "plans": [
                {
                  "planId": "49699e0f-b893-4633-bc05-754b8a562d07"
                }
              ],
              "triggerInfo": {},
              "id": 170,
              "buildNumber": "20181011.8",
              "status": "completed",
              "result": "succeeded",
              "queueTime": "2018-10-11T15:56:24.9611153Z",
              "startTime": "2018-10-11T15:56:28.3668144Z",
              "finishTime": "2018-10-11T15:57:20.5163422Z",
              "url": "https://indiatelecom.visualstudio.com/d354caa2-2e88-414a-829b-25df3aceaaaf/_apis/build/Builds/170",
              "buildNumberRevision": 8,
              "uri": "vstfs:///Build/Build/170",
              "sourceBranch": "refs/heads/master",
              "sourceVersion": "4303c19f8fda79e35fcb598219d5dca6bb274c2d",
              "priority": "normal",
              "reason": "manual",
              "lastChangedDate": "2018-10-11T15:57:20.797Z",
              "parameters": "{\"system.debug\":\"false\"}",
              "orchestrationPlan": {
                "planId": "49699e0f-b893-4633-bc05-754b8a562d07"
              },
              "keepForever": false,
              "retainedByRelease": false,
              "triggeredByBuild": null
            },
            {
              "properties": {},
              "tags": [],
              "validationResults": [],
              "plans": [
                {
                  "planId": "15026a2f-c725-4e52-974b-61e01a940661"
                }
              ],
              "triggerInfo": {},
              "id": 160,
              "buildNumber": "20181009.20",
              "status": "completed",
              "result": "succeeded",
              "queueTime": "2018-10-09T16:47:42.2954075Z",
              "startTime": "2018-10-09T16:47:43.8034575Z",
              "finishTime": "2018-10-09T16:48:35.8340469Z",
              "url": "https://indiatelecom.visualstudio.com/d354caa2-2e88-414a-829b-25df3aceaaaf/_apis/build/Builds/160",
              "buildNumberRevision": 20,
              "uri": "vstfs:///Build/Build/160",
              "sourceBranch": "refs/heads/master",
              "sourceVersion": "19a55c7482083785265b86015150521b40230c11",
              "priority": "normal",
              "reason": "manual",
              "lastChangedDate": "2018-10-09T16:48:36.057Z",
              "parameters": "{\"system.debug\":\"false\"}",
              "orchestrationPlan": {
                "planId": "15026a2f-c725-4e52-974b-61e01a940661"
              },
              "keepForever": false,
              "retainedByRelease": false,
              "triggeredByBuild": null
            },
            {
              "properties": {},
              "tags": [],
              "validationResults": [],
              "plans": [
                {
                  "planId": "e45d9da8-4d95-42b7-aa23-478e1c1c49f5"
                }
              ],
              "triggerInfo": {},
              "id": 147,
              "buildNumber": "20181009.7",
              "status": "completed",
              "result": "succeeded",
              "queueTime": "2018-10-09T15:15:47.0248009Z",
              "startTime": "2018-10-09T15:15:50.8899892Z",
              "finishTime": "2018-10-09T15:16:47.7866356Z",
              "url": "https://indiatelecom.visualstudio.com/d354caa2-2e88-414a-829b-25df3aceaaaf/_apis/build/Builds/147",
              "buildNumberRevision": 7,
              "uri": "vstfs:///Build/Build/147",
              "sourceBranch": "refs/heads/master",
              "sourceVersion": "70fccb138a2f2a9dfe18290c468959102f504067",
              "priority": "normal",
              "reason": "manual",
              "lastChangedDate": "2018-10-09T15:16:48.16Z",
              "parameters": "{\"system.debug\":\"false\"}",
              "orchestrationPlan": {
                "planId": "e45d9da8-4d95-42b7-aa23-478e1c1c49f5"
              },
              "keepForever": false,
              "retainedByRelease": false,
              "triggeredByBuild": null
            }
          ]
        },
        "output": 170
      }
    ],
    "identifier": 52787205
  },
  {
    "context": [
      "I need to remove all array elements that have the `name` field ending with `1`.",
      "jq '.data.items|=map(select(.name|endswith(\"1\")|not))' file",
      "This replace `.data.items` with the a new array having objects whose `name`s don't end with `1`.",
      ".data.items|=map(select(.name|test(\"[^1]$\")))"
    ],
    "utterance": "Remove all objects from the items array where the name field ends with 1.",
    "expressions": [
      ".data.items |= map(select(.name | endswith(\"1\") | not))",
      ".data.items |= map(select(.name | test(\"[^1]$\")))"
    ],
    "data": [
      {
        "input": {
          "foo": "bar",
          "data": {
            "code": "abc123",
            "items": [
              {
                "name": "exp1"
              },
              {
                "name": "exp2"
              },
              {
                "name": "exp11"
              }
            ]
          }
        },
        "output": {
          "foo": "bar",
          "data": {
            "code": "abc123",
            "items": [
              {
                "name": "exp2"
              }
            ]
          }
        }
      }
    ],
    "identifier": 53046253
  },
  {
    "context": [
      "Second, the following jq filter, used in conjunction with the aforementioned `-r` option, should be sufficient to achieve your goals, though it's hard to verify since you haven't provided an [MCVE][1]:",
      ".Reservations[].Instances[].PublicIpAddress\n| \"inst\" + . + \" ansible_ssh_hosts=\" + . + \" ansible_ssh_user=ubuntu\""
    ],
    "utterance": "Produce formatted host lines using each instance's public IP address in the form: inst[ip] ansible_ssh_host=[ip] ansible_ssh_user=ubuntu, for all instances returned by describe-instances, without duplicates.",
    "expressions": [
      ".Reservations[].Instances[].PublicIpAddress | \"inst\" + . + \" ansible_ssh_host=\" + . + \" ansible_ssh_user=ubuntu\""
    ],
    "identifier": 53055418
  },
  {
    "context": [
      "I would like to below code to output  \r\n`KNOCK_KNOCK=&quot;Who is there?&quot;`",
      "$ echo '{\"KNOCK_KNOCK\": \"Who is there?\"}' | jq -r 'to_entries[] | .key + \"=\\\"\" + (.value|tostring) + \"\\\"\"'",
      "jq -r 'to_entries[] | [.key,.value] | join(\"=\")' <<< \"$TEST_FILE\"",
      "| jq -r 'to_entries[] | [.key,(.value|@sh)] | join(\"=\")'"
    ],
    "utterance": "Produce lines assigning each key in the object to its value quoted, as in KNOCK_KNOCK=\"Who is there?\".",
    "expressions": [
      "to_entries[] | .key + \"=\\\"\" + (.value|tostring) + \"\\\"\"",
      "to_entries[] | [.key,.value] | join(\"=\")",
      "to_entries[] | [.key,(.value|@sh)] | join(\"=\")"
    ],
    "data": [
      {
        "input": {
          "KNOCK_KNOCK": "Who is there?"
        },
        "output": "KNOCK_KNOCK=\"Who is there?\""
      }
    ],
    "identifier": 52997801
  },
  {
    "context": [
      "But also I want to search for variables I want to change by their names, not by their number in array.",
      "So how I can change variable by its name and also add \"Job:\" at the same time?",
      "You can use the `|=` \"update-assignment\" operator with the following syntax :",
      "(.TaskGroups[] | select(.Name == (\"test1\", \"test5\")).Count) |= 0 | {Job : . }"
    ],
    "utterance": "Set the Count field to 0 for elements in TaskGroups where Name is \"test1\" or \"test5\", and wrap the result with a new top-level key Job.",
    "expressions": [
      "(.TaskGroups[] | select(.Name == (\"test1\", \"test5\")).Count) |= 0 | {Job : . }"
    ],
    "data": [
      {
        "input": {
          "Name": "test",
          "TaskGroups": [
            {
              "Name": "test1",
              "Count": 1
            },
            {
              "Name": "test2",
              "Count": 1
            },
            {
              "Name": "test3",
              "Count": 1
            },
            {
              "Name": "test4",
              "Count": 1
            },
            {
              "Name": "test5",
              "Count": 1
            }
          ]
        },
        "output": {
          "Job": {
            "Name": "test",
            "TaskGroups": [
              {
                "Name": "test1",
                "Count": 0
              },
              {
                "Name": "test2",
                "Count": 1
              },
              {
                "Name": "test3",
                "Count": 1
              },
              {
                "Name": "test4",
                "Count": 1
              },
              {
                "Name": "test5",
                "Count": 0
              }
            ]
          }
        }
      }
    ],
    "identifier": 53071290
  },
  {
    "context": [
      "You can filter the content using this `jq` filter:",
      "jq 'map({ type: \"Feature\", \"geometry\": {\"type\": \"LineString\",\"coordinates\": [ [.StartLongitude, .StartLatitude| tonumber], [ .EndLongitude, .EndLatitude | tonumber] ] }, properties: {tmc: .TMC, roadnumber: .ROADNUMBER, dir: .DIR, prov: .PROV, ccaa: .CCAA}})' file",
      "resulting in this new JSON data:",
      "[{\n  \"type\": \"Feature\",\n  \"geometry\": {\n    \"type\": \"LineString\",\n    \"coordinates\": [\n      [\n        0.4387071,\n        41.5368273\n      ],\n      [\n        0.4638462,\n        41.5388396\n      ]\n    ]\n  },\n  \"properties\": {\n    \"tmc\": \"E17+02412\",\n    \"roadnumber\": \"A-2\",\n    \"dir\": \"E-90/AP-2/BARCELONA-ZARAGOZA (SOSES)\",\n    \"prov\": \"LLEIDA\",\n    \"ccaa\": \"CATALUNYA\"\n  }\n}]"
    ],
    "utterance": "Transform an array where each object contains fields like StartLongitude, StartLatitude, EndLongitude, EndLatitude, TMC, ROADNUMBER, DIR, PROV, and CCAA into an array of objects with the geo-feature structure: type 'Feature', geometry as a LineString with coordinates using those longitude and latitude values (converted to numbers), and properties containing tmc, roadnumber, dir, prov, and ccaa.",
    "expressions": [
      "map({ type: \"Feature\", geometry: {type: \"LineString\", coordinates: [[.StartLongitude, .StartLatitude|tonumber], [.EndLongitude, .EndLatitude|tonumber]] }, properties: {tmc: .TMC, roadnumber: .ROADNUMBER, dir: .DIR, prov: .PROV, ccaa: .CCAA}})"
    ],
    "data": [
      {
        "input": [
          {
            "TMC": "E17+02412",
            "ROADNUMBER": "A-2",
            "DIR": "E-90/AP-2/BARCELONA-ZARAGOZA (SOSES)",
            "PROV": "LLEIDA",
            "CCAA": "CATALUNYA",
            "StartLatitude": "41.5368273",
            "StartLongitude": "0.4387071",
            "EndLatitude": "41.5388396",
            "EndLongitude": "0.4638462"
          }
        ],
        "output": [
          {
            "type": "Feature",
            "geometry": {
              "type": "LineString",
              "coordinates": [
                [
                  0.4387071,
                  41.5368273
                ],
                [
                  0.4638462,
                  41.5388396
                ]
              ]
            },
            "properties": {
              "tmc": "E17+02412",
              "roadnumber": "A-2",
              "dir": "E-90/AP-2/BARCELONA-ZARAGOZA (SOSES)",
              "prov": "LLEIDA",
              "ccaa": "CATALUNYA"
            }
          }
        ]
      }
    ],
    "identifier": 53065702
  },
  {
    "context": [
      "I want to filter with \"F1\" == \"V11\", and get:",
      "You can use this jq filter:\n\n    jq '.TheArray |= map(select(.F1==\"V11\"))' file",
      ".TheArray |= map(select(.F1==\"V11\"))",
      "with_entries( .value |= map(select(.F1 == \"V11\")))",
      "del(.TheArray[] | select(.F1!=\"V11\"))",
      ".TheArray[] |= select(.F1==\"V11\")"
    ],
    "utterance": "Keep only the objects in TheArray where F1 equals V11, returning the same structure with TheArray filtered.",
    "expressions": [
      ".TheArray |= map(select(.F1==\"V11\"))",
      "with_entries( .value |= map(select(.F1 == \"V11\")))",
      "del(.TheArray[] | select(.F1!=\"V11\"))",
      ".TheArray[] |= select(.F1==\"V11\")"
    ],
    "data": [
      {
        "input": {
          "TheArray": [
            {
              "F1": "V11",
              "F2": "V12",
              "F3": "V13"
            },
            {
              "F1": "V21",
              "F2": "V22",
              "F3": "V33"
            }
          ]
        },
        "output": {
          "TheArray": [
            {
              "F1": "V11",
              "F2": "V12",
              "F3": "V13"
            }
          ]
        }
      }
    ],
    "identifier": 53104102
  },
  {
    "context": [
      "Change your call to `jq` to look like this and then you don&#39;t have to strip the other characters:\r\n\r\n    jq -r '.Role.AssumeRolePolicyDocument.Statement[].Principal.AWS[]'\r\n                                                                   ^^ Add these",
      "You could try this also:\r\n\r\n    aws iam get-role --role-name rl-company-admin --profile=company-bill | \\\r\n      jq -r '.Role.AssumeRolePolicyDocument.Statement[].Principal.AWS[] | split(\"/\") | last' | \\\r\n      grep tdunphy",
      "This might be a bit terse, but you can do it all with one `jq` call:\r\n\r\n    jq -r '[.Role.AssumeRolePolicyDocument.Statement[].Principal.AWS[] | split(\"/\") | last] | map(select(. == \"tdunphy\"))[]'",
      "It can be done in **single `jq`** command like this this avoiding invoking multiple external commands e.g. `grep`, `sed` etc:\r\n\r\n    aws iam get-role --role-name rl-company-admin --profile=company-bill |\r\n    jq --arg u 'tdunphy' -r '\r\n     .Role.AssumeRolePolicyDocument.Statement[].Principal.AWS[] |\r\n     select(. | endswith($u)) | sub(\"arn:aws:iam::123456789101:user/\", \"\")'\r\n\r\n**Output:**\r\n\r\n    tdunphy"
    ],
    "utterance": "Extract the username 'tdunphy' from the AWS principal list where the ARN ends with 'tdunphy', removing the ARN prefix.",
    "expressions": [
      ".Role.AssumeRolePolicyDocument.Statement[].Principal.AWS[] | select(. | endswith(\"tdunphy\")) | sub(\"arn:aws:iam::123456789101:user/\", \"\")",
      ".Role.AssumeRolePolicyDocument.Statement[].Principal.AWS[] | split(\"/\") | last | select(. == \"tdunphy\")",
      "[.Role.AssumeRolePolicyDocument.Statement[].Principal.AWS[] | split(\"/\") | last] | map(select(. == \"tdunphy\"))[]"
    ],
    "data": [
      {
        "input": {
          "Role": {
            "Description": "company Admin Role",
            "AssumeRolePolicyDocument": {
              "Version": "2012-10-17",
              "Statement": [
                {
                  "Action": "sts:AssumeRole",
                  "Effect": "Allow",
                  "Principal": {
                    "AWS": [
                      "arn:aws:iam::123456789101:user/tdunphy",
                      "arn:aws:iam::123456789101:user/user1",
                      "arn:aws:iam::123456789101:user/user2",
                      "arn:aws:iam::123456789101:user/user3"
                    ]
                  }
                }
              ]
            },
            "MaxSessionDuration": 3600,
            "RoleId": "AROAJGNAT3IXV7DIWSDCK",
            "CreateDate": "2018-01-18T17:35:27Z",
            "RoleName": "rl-company-admin",
            "Path": "/",
            "Arn": "arn:aws:iam::188087670762:role/rl-company-admin"
          }
        },
        "output": "tdunphy"
      }
    ],
    "identifier": 53053691
  },
  {
    "context": [
      "I keep getting the error `jq: error (at <stdin>:33): Cannot index string with string \"run\"`",
      "How do I exclude the \"checkout\" string from being selected?",
      "Here&#39;s a solution that is a simple variation of the filter you&#39;ve shown:\r\n\r\n    .[].run?.command",
      "Here&#39;s another variation, which suggests still others:\r\n\r\n    .[] | objects | .run.command",
      "Otherwise if it is truly mixed and any item can be anything, some sort of filtering would have to be done as peak outlines."
    ],
    "utterance": "Select all 'command' fields from elements that are objects containing a 'run' key, ignoring any string elements like 'checkout'.",
    "expressions": [
      ".[].run?.command",
      ".[] | objects | .run.command",
      ".[1:][].run.command"
    ],
    "data": [
      {
        "input": [
          "checkout",
          {
            "run": {
              "command": "pip install cfn-lint pycodestyle pyflakes",
              "name": "Install Dependencies"
            }
          },
          {
            "run": {
              "command": "find stacks -type f -name \"*.yml\" -exec cfn-lint -i E3016 -i E3012 -i E1029 --template {} \\; | tee -a output.txt",
              "name": "Run cfn-lint"
            }
          },
          {
            "run": {
              "command": "find stacks -type f -name \"*.py\" -exec pyflakes {} \\; | tee -a output.txt",
              "name": "Run pyflakes"
            }
          },
          {
            "run": {
              "command": "pycodestyle --show-source --show-pep8 --ignore=E501,W605 stacks/src | tee -a output.txt",
              "name": "Run pycodestyle"
            }
          },
          {
            "run": {
              "command": "if [[ -s output.txt ]]; then cat output.txt; exit 1; fi",
              "name": "Exit if there are validation warnings/errors"
            }
          }
        ],
        "output": [
          "pip install cfn-lint pycodestyle pyflakes",
          "find stacks -type f -name \"*.yml\" -exec cfn-lint -i E3016 -i E3012 -i E1029 --template {} \\; | tee -a output.txt",
          "find stacks -type f -name \"*.py\" -exec pyflakes {} \\; | tee -a output.txt",
          "pycodestyle --show-source --show-pep8 --ignore=E501,W605 stacks/src | tee -a output.txt",
          "if [[ -s output.txt ]]; then cat output.txt; exit 1; fi"
        ]
      }
    ],
    "identifier": 53105673
  },
  {
    "context": [
      "How can I transform a JSON document like this:\r\n\r\n\r\n    { \"foo\": 123, \"bar\": \"abc\" }\r\n\r\ninto something like this:\r\n\r\n\r\n    { \"payload\":  { \"foo\": 123, \"bar\": \"abc\" } }",
      "You just need to wrap an object around the input.\r\n\r\n    jq '{payload: .}' some.json"
    ],
    "utterance": "Wrap the entire input under a top-level key named payload.",
    "expressions": [
      "{payload: .}"
    ],
    "data": [
      {
        "input": {
          "foo": 123,
          "bar": "abc"
        },
        "output": {
          "payload": {
            "foo": 123,
            "bar": "abc"
          }
        }
      }
    ],
    "identifier": 53125290
  },
  {
    "context": [
      "Notably, all your keys come before the string `: `, and the values come after them -- so we want to read line-by-line, split based on colon-space sequences, treat what was in front as a key, and treat what's in back as a value.",
      "jq -Rn '[inputs | split(\": \")] | reduce .[] as $kv ({}; .[$kv[0]] = $kv[1])' < <(write_output)",
      "...properly emits:",
      "{",
      "  \"Repo-id\": \"wazuh_repo\",",
      "  \"Repo-name\": \"Wazuhrepository\",",
      "  \"Repo-status\": \"enabled\",",
      "  \"Repo-revision\": \"1536348945\",",
      "  \"Repo-updated\": \"FriSep712:35:512018\",",
      "  \"Repo-pkgs\": \"73\",",
      "  \"Repo-size\": \"920M\",",
      "  \"Repo-baseurl\": \"https://packages.wazuh.com/3.x/yum/\",",
      "  \"Repo-expire\": \"21,600second(s)(last:WedOct3108:59:002018)\"",
      "}",
      "jq -nR '\n  [inputs | index(\": \") as $ix | {(.[:$ix]): .[$ix+2:]}]\n  | add'",
      "...| jq -Rn 'reduce (inputs | capture(\"(?<k>[^:]+):\\\\s*(?<v>.+)\")) as {$k, $v} ({}; .[$k] = $v)'"
    ],
    "utterance": "Convert a sequence of lines containing 'key: value' pairs into an object mapping each key to its corresponding value.",
    "expressions": [
      "jq -Rn '[inputs | split(\": \")] | reduce .[] as $kv ({}; .[$kv[0]] = $kv[1])'",
      "jq -nR '[inputs | index(\": \") as $ix | {(.[:$ix]): .[$ix+2:]}] | add'",
      "jq -Rn 'reduce (inputs | capture(\"(?<k>[^:]+):\\\\s*(?<v>.+)\")) as {$k, $v} ({}; .[$k] = $v)'"
    ],
    "data": [
      {
        "input": [
          "Repo-id: wazuh_repo",
          "Repo-name: Wazuhrepository",
          "Repo-status: enabled",
          "Repo-revision: 1536348945",
          "Repo-updated: FriSep712:35:512018",
          "Repo-pkgs: 73",
          "Repo-size: 920M",
          "Repo-baseurl: https://packages.wazuh.com/3.x/yum/",
          "Repo-expire: 21,600second(s)(last:WedOct3108:59:002018)"
        ],
        "output": {
          "Repo-id": "wazuh_repo",
          "Repo-name": "Wazuhrepository",
          "Repo-status": "enabled",
          "Repo-revision": "1536348945",
          "Repo-updated": "FriSep712:35:512018",
          "Repo-pkgs": "73",
          "Repo-size": "920M",
          "Repo-baseurl": "https://packages.wazuh.com/3.x/yum/",
          "Repo-expire": "21,600second(s)(last:WedOct3108:59:002018)"
        }
      }
    ],
    "identifier": 53089179
  },
  {
    "context": [
      ".fields.x-amz-credential",
      ".fields.\"Content-Type\"",
      "The basic form for accessing the value of a key is .[\"KEYNAME\"] where \"KEYNAME\" is any valid JSON string, but recent versions of jq also allow .\"KEYNAME\".",
      "Using the basic form might require explicit use of the pipe symbol, as in .[\"a-b\"]|.[\"x-y\"], but this can be abbreviated to .[\"a-b\"][\"x-y\"]."
    ],
    "utterance": "Extract the value of the 'x-amz-credential' key from the 'fields' object where the key contains a hyphen.",
    "expressions": [
      ".fields[\"x-amz-credential\"]"
    ],
    "data": [
      {
        "input": {
          "s3_direct_url": "https://fanzo-photos.s3.amazonaws.com/photos/images/034/005/322/screen1.jpg",
          "url": "https://fanzo-photos.s3.amazonaws.com",
          "fields": {
            "key": "photos/images/034/005/322/screen1.jpg",
            "success_action_status": "200",
            "Content-Type": "image/jpeg",
            "acl": "public-read",
            "policy": "eyJleHBpcmF0aW9uIjoiMjAxOC0xMS0wMlQxMzo0NzoxNVoiLCJjb25kaXRpb25zIjpbeyJidWNrZXQiOiJmYW56by1waG90b3MifSx7ImtleSI6InBob3Rvcy9pbWFnZXMvMDM0LzAwNS8zMjIvc2NyZWVuMS5qcGcifSx7InN1Y2Nlc3NfYWN0aW9uX3N0YXR1cyI6IjIwMCJ9LHsiQ29udGVudC1UeXBlIjoiaW1hZ2UvanBlZyJ9LHsiYWNsIjoicHVibGljLXJlYWQifSx7IngtYW16LWNyZWRlbnRpYWwiOiJBS0lBSlkzWVRCV1NMQzQ2SFdCQS8yMDE4MTEwMi91cy1lYXN0LTEvczMvYXdzNF9yZXF1ZXN0In0seyJ4LWFtei1hbGdvcml0aG0iOiJBV1M0LUhNQUMtU0hBMjU2In0seyJ4LWFtei1kYXRlIjoiMjAxODExMDJUMTI0NzE1WiJ9XX0=",
            "x-amz-credential": "AKIAJY3YTBWSLC46HWBA/20181102/us-east-1/s3/aws4_request",
            "x-amz-algorithm": "AWS4-HMAC-SHA256",
            "x-amz-date": "20181102T124715Z",
            "x-amz-signature": "52d8246536e8743fba8e7668cb65a08a1142221d54a58676b6ab14e3835482a3"
          },
          "id": 34005322,
          "media_type": "InputMedia"
        },
        "output": "AKIAJY3YTBWSLC46HWBA/20181102/us-east-1/s3/aws4_request"
      }
    ],
    "identifier": 53119261
  },
  {
    "context": [
      "I am trying to cut the last word of a json key value using `.split()[-1]` with pyjq, but failing with error: `jq: error: syntax error, unexpected '('`",
      "The key/value - \"subject\": \"The user has user id: 2432343f3f-34kfert-343mn5788886\"",
      "I decided to filter using pyjq.",
      "jq's `split` requires an argument, which must be a valid JSON string.",
      "you would presumably want to write something along the lines of:\n\n    .value[]\n    | { \"id\": [.[\"subject\"] | splits(\"  *\")][-1],\n        \"date\": .receivedDateTime }"
    ],
    "utterance": "Extract the last word (user ID) from the 'subject' field of each object in the array.",
    "expressions": [
      ".[] | { \"id\": ([.subject | splits(\" +\")][-1]), \"date\": .date }"
    ],
    "data": [
      {
        "input": [
          {
            "id": "The user has user id: 76e195fa-67f1-4ea6-bb0e-29c123855978",
            "date": "2018-11-01T08:41:53Z"
          },
          {
            "id": "The user has user id: 195fa76e-67f1-4ea6-bb0e-5597829c1238",
            "date": "2018-10-31T14:43:04Z"
          }
        ],
        "output": [
          {
            "id": "29c123855978",
            "date": "2018-11-01T08:41:53Z"
          },
          {
            "id": "5597829c1238",
            "date": "2018-10-31T14:43:04Z"
          }
        ]
      }
    ],
    "identifier": 53119566
  },
  {
    "context": [
      "The JSON output returned to me after running this command \r\n\r\n    kubectl get pods -o json | jq '.items[].spec.containers[].env'\r\n\r\n \r\non my kuberntes cluster is this\r\n\r\n    [\r\n      {\r\n        \"name\": \"USER_NAME\",\r\n        \"value\": \"USER_NAME_VALUE_A\"\r\n      },\r\n      {\r\n        \"name\": \"USER_ADDRESS\",\r\n        \"value\": \"USER_ADDRESS_VALUE_A\"\r\n      }\r\n    ]\r\n    [\r\n      {\r\n        \"name\": \"USER_NAME\",\r\n        \"value\": \"USER_NAME_VALUE_B\"\r\n      },\r\n      {\r\n        \"name\": \"USER_ADDRESS\",\r\n        \"value\": \"USER_ADDRESS_VALUE_B\"\r\n      }\r\n    ]\r\n\r\nI'd like to create a unified array/dictionary (Using **Bash** script) which looks like the example below and how can I get the value of each key?\r\n\r\n    [\r\n      {\r\n        \"USER_NAME\": \"USER_NAME_VALUE_A\",\r\n        \"USER_ADDRESS\": \"USER_ADDRESS_VALUE_A\"\r\n      },\r\n      {\r\n        \"USER_NAME\": \"USER_NAME_VALUE_B\",\r\n        \"USER_ADDRESS\": \"USER_ADDRESS_VALUE_B\"\r\n      }\r\n    ]",
      "While you are using `jq` as a filter, why not use it as a transformer, too?\r\n```jq\r\nkubectl get pods -o json | \\\r\njq '.items|map(.spec.containers|map(.env|map({key: .name, value})|from_entries)|add)'\r\n```"
    ],
    "utterance": "Transform the list of environment variable objects for each container in all pods into an array of objects mapping variable names to their values.",
    "expressions": [
      ".items|map(.spec.containers|map(.env|map({key: .name, value})|from_entries)|add)"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "spec": {
                "containers": [
                  {
                    "env": [
                      {
                        "name": "USER_NAME",
                        "value": "USER_NAME_VALUE_A"
                      },
                      {
                        "name": "USER_ADDRESS",
                        "value": "USER_ADDRESS_VALUE_A"
                      }
                    ]
                  }
                ]
              }
            },
            {
              "spec": {
                "containers": [
                  {
                    "env": [
                      {
                        "name": "USER_NAME",
                        "value": "USER_NAME_VALUE_B"
                      },
                      {
                        "name": "USER_ADDRESS",
                        "value": "USER_ADDRESS_VALUE_B"
                      }
                    ]
                  }
                ]
              }
            }
          ]
        },
        "output": [
          {
            "USER_NAME": "USER_NAME_VALUE_A",
            "USER_ADDRESS": "USER_ADDRESS_VALUE_A"
          },
          {
            "USER_NAME": "USER_NAME_VALUE_B",
            "USER_ADDRESS": "USER_ADDRESS_VALUE_B"
          }
        ]
      }
    ],
    "identifier": 53121439
  },
  {
    "context": [
      "and from this output, I need to get this address, `snyc3vzezoch2jax.onion` and put into into a text file or a variable.",
      "The `.onion` part always stay the same, although the characters before it will be different each time so I need a general solution to get the whole address.",
      "You can use jq.",
      "addr=$(./xuez-cli getnetworkinfo | jq -r '.localaddresses[0].address // \"something other than null\"')",
      "./xuez-cli getnetworkinfo | jq -r '.localaddresses[0].address // \"something other than null\"' > addrfile"
    ],
    "utterance": "Extract the first value of the 'address' field from the 'localaddresses' array where the address ends with .onion.",
    "expressions": [
      ".localaddresses[0].address // \"something other than null\""
    ],
    "data": [
      {
        "input": {
          "localaddresses": [
            {
              "address": "snyc3vzezoch2jax.onion",
              "port": 41798,
              "score": 4
            }
          ]
        },
        "output": "snyc3vzezoch2jax.onion"
      }
    ],
    "identifier": 53130924
  },
  {
    "context": [
      "`addr=$(./xuez-cli getnetworkinfo | jq -r '.localaddresses[0].address')`",
      "BUT if this `.localaddresses[0].address` part empty or doesn't even exist, jq sets the `addr` variable as `null` like this; `addr=null`",
      "Using `jq -e` will cause `jq`'s exit status to reflect whether it returned content that was either false or null.",
      "if addr=$(./xuez-cli getnetworkinfo | jq -er '.localaddresses[0].address'); then",
      "jq '.foo // empty'",
      "addr=$(./xuez-cli getnetworkinfo | jq -r '.localaddresses[0].address // empty')"
    ],
    "utterance": "Extract the first element's address in localaddresses or return an empty string if it is missing or null.",
    "expressions": [
      ".localaddresses[0].address // empty",
      "-er '.localaddresses[0].address'"
    ],
    "identifier": 53135035
  },
  {
    "context": [
      "I'm in a dire need of help for a script to basically convert JSON text to CSV text in an attempt to copy users from one AWS Cognito userpool to another.",
      "where `%EMAIL%`, `%JOB_TITLE%`, `%USER_ID%`, and `%USERNAME%` are variables, everything else should be just string.",
      "Consider first this filter:",
      ".Users[].Attributes\n    | map(select(.Name | . == \"custom:jobtitle\" or . == \"custom:user_id\" or . == \"email\") )\n    | from_entries\n    | [ .email, .[\"custom:jobtitle\"], .[\"custom:user_id\"] ]\n    | @csv",
      "Assuming valid JSON input along the lines shown in the Q, invoking jq with the -r option would yield:\n\n    \"foo.bar@email.com\",\"Director\",\"38\""
    ],
    "utterance": "Extract each user's email, custom:jobtitle, and custom:user_id attributes as a CSV line.",
    "expressions": [
      ".Users[].Attributes | map(select(.Name == \"custom:jobtitle\" or .Name == \"custom:user_id\" or .Name == \"email\")) | from_entries | [ .email, .[\"custom:jobtitle\"], .[\"custom:user_id\"] ] | @csv"
    ],
    "data": [
      {
        "input": {
          "Users": [
            {
              "Username": "foo.bar",
              "Attributes": [
                {
                  "Name": "sub",
                  "Value": "some-value"
                },
                {
                  "Name": "email_verified",
                  "Value": "true"
                },
                {
                  "Name": "custom:jobtitle",
                  "Value": "Director"
                },
                {
                  "Name": "custom:user_id",
                  "Value": "38"
                },
                {
                  "Name": "email",
                  "Value": "foo.bar@email.com"
                }
              ],
              "UserCreateDate": "2024-04-01T12:00:00Z",
              "UserLastModifiedDate": "2024-05-01T12:00:00Z",
              "Enabled": true,
              "UserStatus": "CONFIRMED"
            }
          ]
        },
        "output": "\"foo.bar@email.com\",\"Director\",\"38\""
      }
    ],
    "identifier": 53127511
  },
  {
    "context": [
      "Using jq how do I select the first returned location with a location_type \"ROOFTOP\" and get the formatted_address and place_id ?",
      "If you want to select only the first one from all objects, use the following:",
      "jq 'map(select(.geometry.location_type==\"ROOFTOP\"))|.[0]|.place_id, .formatted_address' file",
      "Rather than using `.[0]` to obtain the first object satisfying, it would be more efficient to use `first/1`.  Here is a solution using `first/1` and `..`:",
      "$ jq 'first(..|objects|select(.geometry.location_type == \"ROOFTOP\"))\n      | {formatted_address, place_id}' input.json",
      "Retrieving the first top-level object, without using `..`:\n\n    first(.[] | select(.geometry.location_type==\"ROOFTOP\"))"
    ],
    "utterance": "Select the first entry where geometry.location_type is \"ROOFTOP\" and return its formatted_address and place_id.",
    "expressions": [
      "map(select(.geometry.location_type==\"ROOFTOP\"))|.[0]|{formatted_address, place_id}",
      "first(..|objects|select(.geometry.location_type == \"ROOFTOP\")) | {formatted_address, place_id}",
      "first(.[] | select(.geometry.location_type==\"ROOFTOP\")) | {formatted_address, place_id}"
    ],
    "data": [
      {
        "input": [
          {
            "address_components": [
              {
                "long_name": "30",
                "short_name": "30",
                "types": [
                  "street_number"
                ]
              },
              {
                "long_name": "All\u00e9e Jean de Lattre de Tassigny",
                "short_name": "All\u00e9e Jean de Lattre de Tassigny",
                "types": [
                  "route"
                ]
              },
              {
                "long_name": "Montpellier",
                "short_name": "Montpellier",
                "types": [
                  "locality",
                  "political"
                ]
              },
              {
                "long_name": "H\u00e9rault",
                "short_name": "H\u00e9rault",
                "types": [
                  "administrative_area_level_2",
                  "political"
                ]
              },
              {
                "long_name": "Occitanie",
                "short_name": "Occitanie",
                "types": [
                  "administrative_area_level_1",
                  "political"
                ]
              },
              {
                "long_name": "France",
                "short_name": "FR",
                "types": [
                  "country",
                  "political"
                ]
              },
              {
                "long_name": "34000",
                "short_name": "34000",
                "types": [
                  "postal_code"
                ]
              }
            ],
            "formatted_address": "30 All\u00e9e Jean de Lattre de Tassigny, 34000 Montpellier, France",
            "geometry": {
              "bounds": {
                "northeast": {
                  "lat": 43.6097932,
                  "lng": 3.8817559
                },
                "southwest": {
                  "lat": 43.6094097,
                  "lng": 3.881321299999999
                }
              },
              "location": {
                "lat": 43.6095516,
                "lng": 3.881559199999999
              },
              "location_type": "GEOMETRIC_CENTER",
              "viewport": {
                "northeast": {
                  "lat": 43.6109504302915,
                  "lng": 3.882887580291503
                },
                "southwest": {
                  "lat": 43.6082524697085,
                  "lng": 3.880189619708498
                }
              }
            },
            "place_id": "ChIJ13k0paCvthIRcTgwBrisc10",
            "types": [
              "premise"
            ]
          },
          {
            "address_components": [
              {
                "long_name": "8",
                "short_name": "8",
                "types": [
                  "street_number"
                ]
              },
              {
                "long_name": "Rue Michelet",
                "short_name": "Rue Michelet",
                "types": [
                  "route"
                ]
              },
              {
                "long_name": "Montpellier",
                "short_name": "Montpellier",
                "types": [
                  "locality",
                  "political"
                ]
              },
              {
                "long_name": "H\u00e9rault",
                "short_name": "H\u00e9rault",
                "types": [
                  "administrative_area_level_2",
                  "political"
                ]
              },
              {
                "long_name": "Occitanie",
                "short_name": "Occitanie",
                "types": [
                  "administrative_area_level_1",
                  "political"
                ]
              },
              {
                "long_name": "France",
                "short_name": "FR",
                "types": [
                  "country",
                  "political"
                ]
              },
              {
                "long_name": "34000",
                "short_name": "34000",
                "types": [
                  "postal_code"
                ]
              }
            ],
            "formatted_address": "8 Rue Michelet, 34000 Montpellier, France",
            "geometry": {
              "location": {
                "lat": 43.60911189999999,
                "lng": 3.8814264
              },
              "location_type": "ROOFTOP",
              "viewport": {
                "northeast": {
                  "lat": 43.61046088029149,
                  "lng": 3.882775380291502
                },
                "southwest": {
                  "lat": 43.60776291970849,
                  "lng": 3.880077419708498
                }
              }
            },
            "place_id": "ChIJ2UaGt6CvthIRJoNW7vS2Ibs",
            "plus_code": {
              "compound_code": "JV5J+JH Montpellier, France",
              "global_code": "8FM5JV5J+JH"
            },
            "types": [
              "street_address"
            ]
          }
        ],
        "output": {
          "formatted_address": "8 Rue Michelet, 34000 Montpellier, France",
          "place_id": "ChIJ2UaGt6CvthIRJoNW7vS2Ibs"
        }
      }
    ],
    "identifier": 52929094
  },
  {
    "context": [
      "First array file1:\r\n\r\n    [{\"1\":\"2\"}, {\"3\":\"4\"}] ",
      "Second array in file2:\r\n\r\n    [{\"a\":\"b\"}, {\"c\":\"d\"}]",
      "I tried \"jq -s -c '[0][] + .[1][]' file1 file2\". The result: ... However, I want the following:\r\n\r\n    {\"1\":\"2\",\"a\":\"b\"}\r\n    {\"3\":\"4\",\"c\":\"d\"}",
      "An (the?) elegant way:\r\n\r\n    $ jq -n --argfile f1 file1.json --argfile f2 file2.json -f program.jq\r\n\r\nwhere program.jq is:\r\n\r\n    [$f1,$f2]\r\n    | transpose\r\n    | map(add)"
    ],
    "utterance": "Combine objects from two arrays, pairing elements by their positions, and merge each pair into a single object.",
    "expressions": [
      "[$f1,$f2] | transpose | map(add)"
    ],
    "data": [
      {
        "input": [
          [
            {
              "1": "2"
            },
            {
              "3": "4"
            }
          ],
          [
            {
              "a": "b"
            },
            {
              "c": "d"
            }
          ]
        ],
        "output": [
          {
            "1": "2",
            "a": "b"
          },
          {
            "3": "4",
            "c": "d"
          }
        ]
      }
    ],
    "identifier": 53136706
  },
  {
    "context": [
      "The intent for the JSON data below is to update the value of the field `dst` with the value of `src` within all elements of `type` `t`, regardless of depth within the tree, while at the same time preserving the whole structure of the data.",
      "Here's a simple solution:",
      "    walk( if type == \"object\" and .type == \"t\" then .dst = .src else . end)",
      "Alternatively ...",
      "    reduce paths as $x (.;\n        if (getpath($x)|.type? // false) == \"t\"\n        then setpath( $x + [\"dst\"]; getpath( $x + [\"src\"] ))\n        else . end)"
    ],
    "utterance": "Update all fields named 'dst' to the value of 'src' in every object where 'type' equals 't', at any depth in the structure.",
    "expressions": [
      "walk( if type == \"object\" and .type == \"t\" then .dst = .src else . end)",
      "reduce paths as $x (.; if (getpath($x)|.type? // false) == \"t\" then setpath( $x + [\"dst\"]; getpath( $x + [\"src\"] )) else . end)"
    ],
    "data": [
      {
        "input": {
          "a": "b",
          "c": [
            {
              "type": "t",
              "src": "xx",
              "dst": "zz"
            },
            {
              "type": "t",
              "src": "xx",
              "dst": "zz"
            }
          ],
          "d": [
            {
              "e": [
                {
                  "type": "t",
                  "src": "xx",
                  "dst": "zz"
                }
              ]
            },
            {
              "type": "t2",
              "src": "xx",
              "dst": "zz"
            }
          ]
        },
        "output": {
          "a": "b",
          "c": [
            {
              "type": "t",
              "src": "xx",
              "dst": "xx"
            },
            {
              "type": "t",
              "src": "xx",
              "dst": "xx"
            }
          ],
          "d": [
            {
              "e": [
                {
                  "type": "t",
                  "src": "xx",
                  "dst": "xx"
                }
              ]
            },
            {
              "type": "t2",
              "src": "xx",
              "dst": "zz"
            }
          ]
        }
      }
    ],
    "identifier": 53145680
  },
  {
    "context": [
      "I now want to extract the phone numbers of the persons `11111`, `22222`, `33333`, `44444` and `55555` as a semicolon-separated string:\r\n\r\n    123456;432100;;;147258",
      "With your sample input in input.json, and using jq 1.6 (or a jq with INDEX/2), the following invocation of jq produces the desired output:\r\n\r\n    jq -r --argjson ids '[11111, 22222, 33333, 44444, 55555]' -f tossv.jq input.json",
      "assuming tossv.jq contains the program:\r\n\r\n    INDEX(.persons[]; .personID) as $dict\r\n    | $ids\r\n    | map( $dict[tostring] | .phoneNumber)\r\n    | join(\";\")",
      "When using `join(\";\")`, `null` values effectively become empty strings."
    ],
    "utterance": "Extract the phone numbers for the personIDs 11111, 22222, 33333, 44444, and 55555 in that order, using empty strings for any missing IDs, and concatenate them into a semicolon-separated string: 123456;432100;;;147258.",
    "expressions": [
      "INDEX(.persons[]; .personID) as $dict | $ids | map($dict[tostring] | .phoneNumber) | join(\";\")"
    ],
    "data": [
      {
        "input": {
          "persons": [
            {
              "friends": 4,
              "phoneNumber": 123456,
              "personID": 11111
            },
            {
              "friends": 2057,
              "phoneNumber": 432100,
              "personID": 22222
            },
            {
              "friends": 50,
              "phoneNumber": 147258,
              "personID": 55555
            }
          ]
        },
        "output": "123456;432100;;;147258"
      }
    ],
    "identifier": 53156774
  },
  {
    "context": [
      "I was wondering if someone could tell me how to sort the following JSON data into plain text ?",
      "The expected results would be:",
      "hostname username password",
      "host1.net johndoe q1w2e3",
      "host2.com alex    qwerty",
      "host3.org bob     123456",
      "$ jq -r '.[] | .[] | [.host[\"1\"], .username[\"1\"], .password[\"1\"]] | @sh' test.json",
      "which yields:",
      "' \"some.host.name\",' null ' \"123456\",'",
      "' \"another.host.name\",' null ' \"654321\",'",
      "' \"example.com\",' ' \"username\",' ' \"password123\",'"
    ],
    "utterance": "Output a space-separated list of host, username, and password values (fields host[\"1\"], username[\"1\"], password[\"1\"]) for each user object.",
    "expressions": [
      ".[] | .[] | [.host[\"1\"], .username[\"1\"], .password[\"1\"]] | @sh"
    ],
    "data": [
      {
        "input": [
          {
            "@hrinn": {
              "host": {
                "1": " \"some.host.name\",",
                "2": " false,"
              },
              "password": {
                "1": " \"123456\","
              }
            }
          },
          {
            "@hrinn": {
              "host": {
                "1": " \"another.host.name\",",
                "2": " false,"
              },
              "password": {
                "1": " \"654321\","
              }
            }
          },
          {
            "@Abnerene": {
              "host": {
                "1": " \"example.com\",",
                "2": " false,"
              },
              "username": {
                "1": " \"username\","
              },
              "password": {
                "1": " \"password123\","
              }
            }
          }
        ],
        "output": [
          "' \"some.host.name\",' null ' \"123456\",'",
          "' \"another.host.name\",' null ' \"654321\",'",
          "' \"example.com\",' ' \"username\",' ' \"password123\",'"
        ]
      }
    ],
    "identifier": 53148443
  },
  {
    "context": [
      "I want to merge these files such that the output file looks like",
      "How can i accomplish this using jq? Thank you for  your assistance",
      "($file2 | map( {(.name): {size, status}} )|add) as $dict\n| $file1\n| .storage_attachments |= map(. + $dict[.storage_volume_name])"
    ],
    "utterance": "Add size and status fields from a second file to each storage_attachments entry, matching on storage_volume_name.",
    "expressions": [
      "($file2 | map( {(.name): {size, status}} )|add) as $dict | $file1 | .storage_attachments |= map(. + $dict[.storage_volume_name])"
    ],
    "data": [
      {
        "input": [
          {
            "hostname": "samplevm",
            "state": "running",
            "storage_attachments": [
              {
                "index": 1,
                "name": "/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/ae53e3fb-0f90-4b93-adf5-1eee2ec78b00/0dc4d0cd-4be1-4220-b10b-5a1b105f1678",
                "storage_volume_name": "/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/boot"
              },
              {
                "index": 2,
                "name": "/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/ae53e3fb-0f90-4b93-adf5-1eee2ec78b00/1ac17918-c999-49a1-b200-957b2d56dbf7",
                "storage_volume_name": "/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/user_data2"
              },
              {
                "index": 3,
                "name": "/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/ae53e3fb-0f90-4b93-adf5-1eee2ec78b00/a068182e-882f-4314-bf00-0a4001935b26",
                "storage_volume_name": "/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/user_data1"
              },
              {
                "index": 4,
                "name": "/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/ae53e3fb-0f90-4b93-adf5-1eee2ec78b00/117a5abe-c5dd-43a6-8935-bebb739d358b",
                "storage_volume_name": "/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/bits"
              },
              {
                "index": 5,
                "name": "/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/ae53e3fb-0f90-4b93-adf5-1eee2ec78b00/ae5c5916-0a21-492e-ae20-5dd0fb383f0f",
                "storage_volume_name": "/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/data"
              }
            ]
          },
          [
            {
              "name": "/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/bits",
              "size": "64424509440",
              "status": "Online"
            },
            {
              "name": "/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/boot",
              "size": "34359738368",
              "status": "Online"
            },
            {
              "name": "/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/data",
              "size": "536870912000",
              "status": "Online"
            },
            {
              "name": "/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/user_data1",
              "size": "912680550400",
              "status": "Online"
            },
            {
              "name": "/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/user_data2",
              "size": "80530636800",
              "status": "Online"
            }
          ]
        ],
        "output": {
          "hostname": "samplevm",
          "state": "running",
          "storage_attachments": [
            {
              "index": 1,
              "name": "/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/ae53e3fb-0f90-4b93-adf5-1eee2ec78b00/0dc4d0cd-4be1-4220-b10b-5a1b105f1678",
              "storage_volume_name": "/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/boot",
              "size": "34359738368",
              "status": "Online"
            },
            {
              "index": 2,
              "name": "/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/ae53e3fb-0f90-4b93-adf5-1eee2ec78b00/1ac17918-c999-49a1-b200-957b2d56dbf7",
              "storage_volume_name": "/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/user_data2",
              "size": "80530636800",
              "status": "Online"
            },
            {
              "index": 3,
              "name": "/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/ae53e3fb-0f90-4b93-adf5-1eee2ec78b00/a068182e-882f-4314-bf00-0a4001935b26",
              "storage_volume_name": "/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/user_data1",
              "size": "912680550400",
              "status": "Online"
            },
            {
              "index": 4,
              "name": "/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/ae53e3fb-0f90-4b93-adf5-1eee2ec78b00/117a5abe-c5dd-43a6-8935-bebb739d358b",
              "storage_volume_name": "/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/bits",
              "size": "64424509440",
              "status": "Online"
            },
            {
              "index": 5,
              "name": "/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/ae53e3fb-0f90-4b93-adf5-1eee2ec78b00/ae5c5916-0a21-492e-ae20-5dd0fb383f0f",
              "storage_volume_name": "/myaccount/user1@mycompany.com/cloud/samplevm/db_1/vm-1/data",
              "size": "536870912000",
              "status": "Online"
            }
          ]
        }
      }
    ],
    "identifier": 53074931
  }
]