[
  {
    "identifier": 50955866
  },
  {
    "context": [
      "$ echo '1 2 3' | jq .",
      "1",
      "2",
      "3",
      "$ echo '1 2 3' | jq --slurp",
      "[",
      "  1,",
      "  2,",
      "  3",
      "]"
    ],
    "utterance": "Read multiple numbers separated by spaces and collect them into an array.",
    "expressions": [
      "jq --slurp ."
    ],
    "data": [
      {
        "input": "1 2 3",
        "output": [
          1,
          2,
          3
        ]
      }
    ],
    "identifier": 50960648
  },
  {
    "context": [
      "So i want to find al the keys in the nested json.",
      "What i did : jq 'keys' 474.json",
      "What iam getting is the top level keys,but my report key has a value which is multi-level nested.So is there any way to print all keys inside this nested JSON using Jq.?",
      "Use a filter to get all the paths to all elements in the input and join them using `join`.",
      "paths | map(tostring) | join(\".\")",
      "`paths` outputs the paths to all the elements in its input (except it does not output the empty list, representing . itself)."
    ],
    "utterance": "List all the keys, including those at all levels of nesting, within a multilevel nested structure.",
    "expressions": [
      "paths | map(tostring) | join(\".\")"
    ],
    "identifier": 50944224
  },
  {
    "context": [
      "my goal is to return the id related to the test object. The desired return value is `55555`.",
      "jq '.[] | select( .name| contains(\"test\")) | .id'"
    ],
    "utterance": "Return the id of the element whose name is 'test'.",
    "expressions": [
      ".[] | select(.name | contains(\"test\")) | .id"
    ],
    "data": [
      {
        "input": [
          {
            "attributes": null,
            "id": "44444",
            "name": "production",
            "type": "system_group"
          },
          {
            "attributes": null,
            "id": "55555",
            "name": "test",
            "type": "system_group"
          },
          {
            "attributes": null,
            "id": "66666",
            "name": "uat",
            "type": "system_group"
          }
        ],
        "output": "55555"
      }
    ],
    "identifier": 50943035
  },
  {
    "context": [
      "how do i achieve the sample output where it is not nested by row?",
      "The `*` operator, given two dictionaries, merges their contents. Thus,\n\n    jq '[.[] | (. * .Row) | del(.Row)]'\n\n...emits as output, when given your input:",
      "Applying the following filter to the \"input\" as shown, yields the desired result:\n\n    map( with_entries( if .key == \"Row\" then .value|to_entries[] else . end) )"
    ],
    "utterance": "Remove the 'Row' nesting from each element so that its contents are merged into the top-level objects while preserving other keys like 'fighter'.",
    "expressions": [
      "[.[] | (. * .Row) | del(.Row)]",
      "map( with_entries( if .key == \"Row\" then .value|to_entries[] else . end) )"
    ],
    "data": [
      {
        "input": [
          {
            "Row": {
              "ganjalord": {
                "latitude": "56.237480",
                "temp": 44
              }
            },
            "fighter": "1"
          },
          {
            "Row": {
              "ganjalord": {
                "latitude": "53.237480",
                "temp": 42
              }
            },
            "fighter": "0"
          }
        ],
        "output": [
          {
            "ganjalord": {
              "latitude": "56.237480",
              "temp": 44
            },
            "fighter": "1"
          },
          {
            "ganjalord": {
              "latitude": "53.237480",
              "temp": 42
            },
            "fighter": "0"
          }
        ]
      }
    ],
    "identifier": 50950522
  },
  {
    "context": [
      "Desired output:\r\n\r\n    {\r\n      \"title\": \"item01\",\r\n      \"color\": \"blue\",\r\n      \"longDescription\": \"This a long description with a keywordA\"\r\n    }",
      "I am able to get the title and the description `jq '.data.products[] | {title: .title, longDescription: .skus[].details.longDescription } | select(.longDescription | contains(\"keywordA\") )'`",
      "However, if I include color in the filter, I get inaccurate data.",
      "There are many possibilities, but the following filter, which uses a \"generate and test\" approach, does produce the desired result and illustrates some possible techniques:\r\n\r\n    .data.products[]\r\n    | {title} + (.skus[] | {color} + (.details | {longDescription}))\r\n    | select(.longDescription | contains(\"keywordA\"))"
    ],
    "utterance": "Extract objects containing title, color, and longDescription fields where longDescription contains \"keywordA\".",
    "expressions": [
      ".data.products[] | {title} + (.skus[] | {color} + (.details | {longDescription})) | select(.longDescription | contains(\"keywordA\"))"
    ],
    "data": [
      {
        "input": {
          "data": {
            "products": [
              {
                "id": "1",
                "title": "item01",
                "description": "item01 description",
                "skus": [
                  {
                    "color": "blue",
                    "precision": 2,
                    "details": {
                      "longDescription": "This a long description with a keywordA"
                    }
                  },
                  {
                    "color": "green",
                    "precision": 1,
                    "details": {
                      "longDescription": ""
                    }
                  }
                ]
              },
              {
                "id": "2",
                "title": "item02",
                "description": "item02 description",
                "skus": [
                  {
                    "color": "red",
                    "precision": 2,
                    "details": {
                      "longDescription": ""
                    }
                  },
                  {
                    "color": "yellow",
                    "precision": 1,
                    "details": {
                      "longDescription": ""
                    }
                  }
                ]
              }
            ]
          }
        },
        "output": {
          "title": "item01",
          "color": "blue",
          "longDescription": "This a long description with a keywordA"
        }
      }
    ],
    "identifier": 50978470
  },
  {
    "context": [
      "I need to give one of the models as input and I want the corresponding name of the car will be the output.",
      "With this filter in the file cars.jq:\n\n    .cars[]\n    | select(.models|index($model))\n    | .name",
      "As a one-liner:\n\n    jq --arg model Panda '.cars[] | select(.models|index($model)) | .name' cars.json"
    ],
    "utterance": "Given a model name as input, return the name of the car that offers this model.",
    "expressions": [
      ".cars[] | select(.models|index($model)) | .name"
    ],
    "data": [
      {
        "input": {
          "cars": [
            {
              "name": "Ford",
              "models": [
                "Fiesta",
                "Focus",
                "Mustang"
              ]
            },
            {
              "name": "BMW",
              "models": [
                "320",
                "X3",
                "X5"
              ]
            },
            {
              "name": "Fiat",
              "models": [
                "500",
                "Panda"
              ]
            }
          ]
        },
        "output": "Fiat"
      }
    ],
    "identifier": 50996434
  },
  {
    "context": [
      "How can I remove \"overview\" field and values from this string.",
      "Then, remove the overview keys using [tag:jq]",
      "$ new_json=$(echo \"$result\" | jq 'map(del(.overview))')"
    ],
    "utterance": "Remove the \"overview\" key and its values from each object in an array.",
    "expressions": [
      "map(del(.overview))"
    ],
    "data": [
      {
        "input": [
          {
            "id": 668,
            "overview": "All versions of `react-marked-markdown` are vulnerable to cross-site scripting (XSS) via `href` attributes. This is exploitable if user is provided to `react-marked-markdown`\n\nProof of concept:\n\n```\nimport React from 'react'\nimport ReactDOM from 'react-dom'\nimport { MarkdownPreview } from 'react-marked-markdown'\n\nReactDOM.render(\n<MarkdownPreview\nmarkedOptions={{ sanitize: true }}\nvalue={'[XSS](javascript: alert`1`)'}/>,\ndocument.getElementById('root')\n)\n```",
            "recommendation": "No fix is currently available for this vulnerability. It is our recommendation to not install or use this module at this time if you allow user input into href values.",
            "cvss_vector": "CVSS:3.0/AV:N/AC:L/PR:N/UI:R/S:C/C:H/I:H/A:N",
            "cvss_score": 9.3,
            "module": "react-marked-markdown"
          },
          {
            "id": 577,
            "overview": "Versions of `lodash` before 4.17.5 are vulnerable to prototype pollution. \n\nThe vulnerable functions are 'defaultsDeep', 'merge', and 'mergeWith' which allow a malicious user to modify the prototype of `Object` via `__proto__` causing the addition or modification of an existing property that will exist on all objects.\n\n",
            "recommendation": "Update to version 4.17.5 or later.",
            "cvss_vector": null,
            "cvss_score": 2,
            "module": "lodash",
            "version": "3.10.1"
          }
        ],
        "output": [
          {
            "id": 668,
            "recommendation": "No fix is currently available for this vulnerability. It is our recommendation to not install or use this module at this time if you allow user input into href values.",
            "cvss_vector": "CVSS:3.0/AV:N/AC:L/PR:N/UI:R/S:C/C:H/I:H/A:N",
            "cvss_score": 9.3,
            "module": "react-marked-markdown"
          },
          {
            "id": 577,
            "recommendation": "Update to version 4.17.5 or later.",
            "cvss_vector": null,
            "cvss_score": 2,
            "module": "lodash",
            "version": "3.10.1"
          }
        ]
      }
    ],
    "identifier": 50974532
  },
  {
    "context": [
      "I want to filter the stream on the command line so I only get:\r\n\r\n    { \r\n       \"isoDateTime\" : \"2018-06-20T15:52:42.466913985Z\",\r\n       \"method\" : \"POST\",\r\n       \"username\" : \"rd7y1\",\r\n       \"requestHeaders.user-agent\" : \"Rcurl\"\r\n    }",
      "So in your case, you'd end up with something like:\r\n\r\n    < /logs/json.log jq '\r\n      select(.requestHeaders.\"user-agent\" == \"curl/7.51.0\")\r\n      | {isoDateTime, method, username,\r\n         \"requestHeaders.user-agent\": .requestHeaders.\"user-agent\"}'"
    ],
    "utterance": "Filter objects to those where requestHeaders.user-agent equals curl/7.51.0 and output only isoDateTime, method, username, and requestHeaders.user-agent as a flattened key.",
    "expressions": [
      "select(.requestHeaders.\"user-agent\" == \"curl/7.51.0\") | {isoDateTime, method, username, \"requestHeaders.user-agent\": .requestHeaders.\"user-agent\"}"
    ],
    "data": [
      {
        "input": {
          "localHostName": "rest-2-17ve6",
          "port": "80",
          "requestHeaders": {
            "x-forwarded-port": "443",
            "x-forwarded-host": "dummy.com",
            "content-length": "15959431",
            "accept": "*/*",
            "x-forwarded-for": "10.1.9.11",
            "authorization": "hash is present",
            "expect": "100-continue",
            "forwarded": "for=10.5.9.1;host=dummy.com;proto=https",
            "content-type": "application/json",
            "host": "dummy.com",
            "x-forwarded-proto": "https",
            "user-agent": "curl/7.51.0"
          },
          "uri": "/2/data/saveList",
          "protocol": "HTTP/1.1",
          "threadName": "http-nio-8080-exec-10",
          "requestBytes": 15959431,
          "applicationDuration": 44135,
          "responseStatus": "200",
          "remoteIpAddress": "10.1.10.1",
          "responseHeaders": {
            "X-XSS-Protection": "1; mode=block",
            "Content-Type": "application/json;charset=UTF-8",
            "X-Content-Type-Options": "nosniff",
            "Cache-Control": "no-cache, no-store, max-age=0, must-revalidate",
            "Date": "Wed, 20 Jun 2018 15:53:27 GMT",
            "Transfer-Encoding": "chunked",
            "Vary": "Accept-Encoding",
            "X-Frame-Options": "DENY",
            "Expires": "0",
            "Pragma": "no-cache"
          },
          "isoDateTime": "2018-06-20T15:52:42.466913985Z",
          "method": "POST",
          "username": "rd7y1",
          "localIpAddress": "10.129.9.238",
          "responseBytes": 2,
          "requestContentExcerpt": "blah",
          "totalDuration": 44869,
          "responseContentExcerpt": " [] "
        },
        "output": {
          "isoDateTime": "2018-06-20T15:52:42.466913985Z",
          "method": "POST",
          "username": "rd7y1",
          "requestHeaders.user-agent": "curl/7.51.0"
        }
      }
    ],
    "identifier": 50954003
  },
  {
    "context": [
      "Looking to change all the values of name to Lower Case.",
      "Sample input:",
      "[  \n   {  \n      \"data_node\":{  \n         \"name\":\"FRODO BAGGINS\",\n         \"race\":\"hobbit\",\n         \"existence\":\"middle earth\"\n      },\n      \"parent\":\"bilbo baggins\"\n   },\n   ...\n]",
      "Sample output:",
      "[  \n   {  \n      \"data_node\":{  \n         \"name\":\"frodo baggins\",\n         \"race\":\"hobbit\",\n         \"existence\":\"middle earth\"\n      },\n      \"parent\":\"bilbo baggins\"\n   },\n   ...\n]",
      "I am currently running \n    map( .[].data_node.name |= ascii_downcase)\n\nand receive `jq: error (at data3.json:538): explode input must be a string` error.",
      "Add an `if` condition to do the case conversion only _if_ the `name` field is not `null` as\n    map( if (.data_node.name != null) then .data_node.name |= ascii_downcase else . end )",
      "More briefly and more robustly:\n    map(.data_node.name |= if type == \"string\" then ascii_downcase else . end)",
      "Or still more briefly:\n    map(.data_node.name |= ascii_downcase? // .)"
    ],
    "utterance": "Convert all 'name' fields under 'data_node' to lower case only when they are strings, leaving null values unchanged.",
    "expressions": [
      "map( if (.data_node.name != null) then .data_node.name |= ascii_downcase else . end )",
      "map(.data_node.name |= if type == \"string\" then ascii_downcase else . end)",
      "map(.data_node.name |= ascii_downcase? // .)"
    ],
    "data": [
      {
        "input": [
          {
            "data_node": {
              "name": "FRODO BAGGINS",
              "race": "hobbit",
              "existence": "middle earth"
            },
            "parent": "bilbo baggins"
          },
          {
            "data_node": {
              "name": "SAMWISE GAMJEE",
              "race": "hobbit",
              "existence": "middle earth"
            },
            "parent": "gamjee lord"
          },
          {
            "data_node": {
              "name": null,
              "race": "hobbit",
              "existence": "middle earth"
            },
            "parent": "bilbo baggins"
          }
        ],
        "output": [
          {
            "data_node": {
              "name": "frodo baggins",
              "race": "hobbit",
              "existence": "middle earth"
            },
            "parent": "bilbo baggins"
          },
          {
            "data_node": {
              "name": "samwise gamjee",
              "race": "hobbit",
              "existence": "middle earth"
            },
            "parent": "gamjee lord"
          },
          {
            "data_node": {
              "name": null,
              "race": "hobbit",
              "existence": "middle earth"
            },
            "parent": "bilbo baggins"
          }
        ]
      }
    ],
    "identifier": 50943201
  },
  {
    "context": [
      "I\u2019m trying to extract just one child field array and convert it to CSV where field keys are a single header row and values of each array item form the subsequent rows.",
      "jq -r '.result.fields | (.[0] | keys) , .[] | [.[] | tostring] | @csv'",
      "So the real question is: can I unpack result.fields once and then work with what that gives me? And if not, is there a more efficient way to arrive at the CSV structure I\u2019m looking for?",
      "Your code is buggy, because `keys` sorts the keys. What\u2019s needed here is `keys_unsorted`.",
      "The following does avoid one very small inefficiency of your approach:\n\n    .result.fields\n    | (.[0] | keys_unsorted), \n      (.[] | [.[] | tostring])\n    | @csv"
    ],
    "utterance": "Produce CSV where the first row lists the keys of objects in 'result.fields' and each subsequent row contains the stringified values, maintaining original key order.",
    "expressions": [
      ".result.fields | (.[0] | keys_unsorted), (.[] | [.[] | tostring]) | @csv"
    ],
    "data": [
      {
        "input": {
          "result": {
            "fields": [
              {
                "aggregatable": true,
                "aiPredictionField": false,
                "autoNumber": false,
                "byteLength": 18,
                "name": "Id"
              },
              {
                "aggregatable": true,
                "aiPredictionField": false,
                "autoNumber": false,
                "byteLength": 18,
                "name": "OwnerId"
              },
              {
                "aggregatable": false,
                "aiPredictionField": false,
                "autoNumber": false,
                "byteLength": 0,
                "name": "IsDeleted"
              }
            ]
          }
        },
        "output": [
          "\"aggregatable\",\"aiPredictionField\",\"autoNumber\",\"byteLength\",\"name\"",
          "\"true\",\"false\",\"false\",\"18\",\"Id\"",
          "\"true\",\"false\",\"false\",\"18\",\"OwnerId\"",
          "\"false\",\"false\",\"false\",\"0\",\"IsDeleted\""
        ]
      }
    ],
    "identifier": 50986055
  },
  {
    "context": [
      "$ echo value | jq -sR --arg key a '{\"$key\": .}'",
      "{",
      "  \"$key\": \"value\\n\"",
      "}",
      "$ echo value | jq -sR --arg key a '{$key: .}'",
      "jq: error: syntax error, unexpected ':', expecting '}' (Unix shell quoting issues?) at <top-level>, line 1:",
      "{$key: .}     ",
      "jq: 1 compile error",
      "When a variable is used to specify a key name, it must be enclosed in parentheses: ",
      "    {($key): .}",
      "In fact, whenever a key-value pair is specified with a colon, the key must be enclosed in parentheses unless it is a JSON string constant."
    ],
    "utterance": "Create an object whose key is the value of a variable and whose value is the input string.",
    "expressions": [
      "{($key): .}"
    ],
    "data": [
      {
        "input": "value\n",
        "output": {
          "a": "value\n"
        }
      }
    ],
    "identifier": 51056808
  },
  {
    "context": [
      "Now all I want is to pass environment variables to key password and basicAuthPassword and to generate new json file as below:",
      "jq --arg p \"password\" '.password = $p | .basicAuthPassword =  $p' < input.json",
      ".password = env.password"
    ],
    "utterance": "Replace both password and basicAuthPassword fields with a value provided via an environment variable or argument.",
    "expressions": [
      "jq --arg p \"$password\" '.password = $p | .basicAuthPassword = $p' < input.json",
      "jq '.password = env.password | .basicAuthPassword = env.password' < input.json"
    ],
    "data": [
      {
        "input": {
          "name": "Job",
          "type": "xdb",
          "typeLogoUrl": "public/app/plugins/logo.svg",
          "access": "proxy",
          "url": "http://xdb:80",
          "password": {},
          "user": "xx",
          "database": "Job",
          "basicAuth": true,
          "basicAuthUser": "xx",
          "basicAuthPassword": {},
          "withCredentials": true,
          "isDefault": false,
          "jsonData": {},
          "secureJsonFields": null
        },
        "output": {
          "name": "Job",
          "type": "xdb",
          "typeLogoUrl": "public/app/plugins/logo.svg",
          "access": "proxy",
          "url": "http://xdb:80",
          "password": "password",
          "user": "xx",
          "database": "Job",
          "basicAuth": true,
          "basicAuthUser": "xx",
          "basicAuthPassword": "password",
          "withCredentials": true,
          "isDefault": false,
          "jsonData": {},
          "secureJsonFields": null
        }
      }
    ],
    "identifier": 51043662
  },
  {
    "context": [
      "I am using awscli and trying to get the value of **IpAddress** from the output of my query.",
      "This is the case:",
      "{ \"MountTargets\": [ { \"MountTargetId\": \"fsmt-bb29e666\", \"IpAddress\": \"172.20.33.255\", \"OwnerId\": \"668225551666\", \"SubnetId\": \"subnet-0b61377039d31e666\", \"NetworkInterfaceId\": \"eni-045f6ea1376662bdf\", \"FileSystemId\": \"fs-089b5e66\", \"LifeCycleState\": \"available\" } ] }",
      "And this is the command I am using to get the IpAddress:",
      "echo array | jq '.[]MountTarget[]s.IpAddress'",
      "Your syntax to access array is wrong. To get the IP address, use this:",
      "jq '.MountTargets[0].IpAddress'"
    ],
    "utterance": "Extract the IpAddress value of the first object in the MountTargets array where that array is under the MountTargets key.",
    "expressions": [
      ".MountTargets[0].IpAddress"
    ],
    "data": [
      {
        "input": {
          "MountTargets": [
            {
              "MountTargetId": "fsmt-bb29e666",
              "IpAddress": "172.20.33.255",
              "OwnerId": "668225551666",
              "SubnetId": "subnet-0b61377039d31e666",
              "NetworkInterfaceId": "eni-045f6ea1376662bdf",
              "FileSystemId": "fs-089b5e66",
              "LifeCycleState": "available"
            }
          ]
        },
        "output": "172.20.33.255"
      }
    ],
    "identifier": 51055912
  },
  {
    "context": [
      "As you see, the field description contains back tick value. In this case, jq fails and return empty string (as not found value for count)",
      "`jq` does not have any problem at all with backticks in literal values.",
      "jq -er \\\n     --arg target_name \"$APINAME\" \\\n     --arg target_version \"$APIVERSION\" '\n  .list[] |\n  select(.name == $target_name) |\n  select(.version == $target_version) |\n  .id' <<<\"$1\"",
      "...the correct result of:\n\n6d2822e5-a90d-4738-b7b7-ef7d7848cb48"
    ],
    "utterance": "Extract the id of the entry in list where name is SwaggerPetstore and version is 1.0.0, even if the description contains backticks.",
    "expressions": [
      ".list[] | select(.name == \"SwaggerPetstore\") | select(.version == \"1.0.0\") | .id"
    ],
    "data": [
      {
        "input": {
          "count": 1,
          "next": "",
          "previous": "",
          "list": [
            {
              "id": "6d2822e5-a90d-4738-b7b7-ef7d7848cb48",
              "name": "SwaggerPetstore",
              "description": "`special key`",
              "context": "/v2",
              "version": "1.0.0",
              "provider": "admin",
              "status": "CREATED",
              "thumbnailUri": null
            }
          ],
          "pagination": {
            "total": 1,
            "offset": 0,
            "limit": 25
          }
        },
        "output": "6d2822e5-a90d-4738-b7b7-ef7d7848cb48"
      }
    ],
    "identifier": 51071637
  },
  {
    "context": [
      "Using jq I need to delete a specific key:value pair if value contains string \"null\". The string could be \" null\" or \"null \". Hence need to use contains and not exact string match.",
      "If not a string it will be a number",
      "The null value is expected only in the 'th' and 'sf' keys",
      "If you want the scope of the changes to be as narrow as possible, you could use map_values, e.g. in conjunction with a helper function for checking and possibly deleting a specific key:",
      "def delkey(key): if key | isnull then del(key) else . end;",
      ".dets |= map_values(.config |= (delkey(.th) | delkey(.sf)))",
      "If there are several specific keys to be checked, it might be more convenient to define a function for checking a list of keys:",
      "def delkeys(keys):",
      "  with_entries(select(.key as $k",
      "    | (keys|index($k)) and (.value|isnull) | not));",
      ".dets |= map_values(.config |= delkeys([\"th\", \"sf\"]))"
    ],
    "utterance": "Delete the 'th' and 'sf' key-value pairs inside each 'config' object when their value contains the substring 'null' (with possible surrounding whitespace) or is null.",
    "expressions": [
      "def isnull: . == null or (type==\"string\" and test(\"^ *null *$\"));\ndef delkey(key): if key | isnull then del(key) else . end;\n.dets |= map_values(.config |= (delkey(.th) | delkey(.sf)))",
      "def isnull: . == null or (type==\"string\" and test(\"^ *null *$\"));\ndef delkeys(keys):\n  with_entries(select(.key as $k | (keys|index($k)) and (.value|isnull) | not));\n.dets |= map_values(.config |= delkeys([\"th\", \"sf\"]))"
    ],
    "data": [
      {
        "input": {
          "dets": {
            "S1": {
              "type": "class",
              "input": [
                12,
                7,
                6,
                19
              ],
              "config": {
                "file": "sfile1",
                "th": -10,
                "sf": "null"
              }
            },
            "S2": {
              "type": "class",
              "input": [
                12,
                7,
                6,
                19
              ],
              "config": {
                "file": "sfile2",
                "th": -5,
                "sf": 3
              }
            },
            "S3": {
              "type": "bottom",
              "input": [
                12,
                7,
                16
              ],
              "config": {
                "file": "sfile3",
                "th": " null",
                "sf": "null "
              }
            }
          }
        },
        "output": {
          "dets": {
            "S1": {
              "type": "class",
              "input": [
                12,
                7,
                6,
                19
              ],
              "config": {
                "file": "sfile1",
                "th": -10
              }
            },
            "S2": {
              "type": "class",
              "input": [
                12,
                7,
                6,
                19
              ],
              "config": {
                "file": "sfile2",
                "th": -5,
                "sf": 3
              }
            },
            "S3": {
              "type": "bottom",
              "input": [
                12,
                7,
                16
              ],
              "config": {
                "file": "sfile3"
              }
            }
          }
        }
      }
    ],
    "identifier": 50997834
  },
  {
    "context": [
      "select (.name==\"$sD\") # this line isnt working.",
      "When i do select (.name==\"TEST\") # it works properly"
    ],
    "utterance": "Select objects where the name field is equal to the value of a shell variable.",
    "expressions": [
      "select(.name == \"$sD\")"
    ],
    "identifier": 51094066
  },
  {
    "context": [
      "the jq incantation to do this piece of magic is:\n\n    jq -r \"with_entries(select([.key] | inside([\\\"bar\\\",\\\"baz\\\",\\\"qux\\\"]))\" file.json",
      "When I run `jq_select_keys foo.json bar baz qux` on my fish shell, I get the following output:\n\n    Command: jq -r \"with_entries(select([.key] | inside([\\\"bar\\\",\\\"baz\\\",\\\"qux\\\"]))\" foo.json\n    with_entries(select([.key] | inside([\"bar\",\"baz\",\"qux\"]))",
      "$ jqs file.json foo baz\n{\n  \"foo\": \"a\",\n  \"baz\": \"c\"\n}",
      "jq -r --slurpfile keys (printf '\"%s\"\\n' $argv[2..-1] | psub) \\\n    'with_entries(select([.key] | inside($keys)))' $argv[1]",
      "the result is:\n\n    function jq_select_keys --description 'Selects given keys from json input'\n        set key_names \\\"$argv[2..-1]\\\"\n        set key_names_joined (string join \",\" $key_names)\n        set jq_args \"with_entries(select([.key] | inside([$key_names_joined])))\"\n        echo \"Command: jq -r $jq_args $argv[1]\"\n        jq -r $jq_args $argv[1]"
    ],
    "utterance": "Extract a subset of an object's keys given a list of key names (e.g., bar, baz, qux), keeping only those keys and their values.",
    "expressions": [
      "with_entries(select([.key] | inside([\"bar\",\"baz\",\"qux\"])))",
      "with_entries(select([.key] | inside($keys)))"
    ],
    "data": [
      {
        "input": {
          "foo": "a",
          "bar": "b",
          "baz": "c"
        },
        "output": {
          "bar": "b",
          "baz": "c"
        }
      },
      {
        "input": {
          "foo": "a",
          "bar": "b",
          "baz": "c"
        },
        "output": {
          "foo": "a",
          "baz": "c"
        }
      }
    ],
    "identifier": 51080019
  },
  {
    "context": [
      "You can use this `jq` command:\n\n    jq -r '.environment.stage.testing[].filepath' env.json",
      "Notice the keyword `filepath` instead of `filePath` in your command.",
      "The filter that corresponds with the posted data is:\n\n    .environment.stage.testing[].filepath"
    ],
    "utterance": "Extract the value of 'filepath' for all objects in the 'environment.stage.testing' array.",
    "expressions": [
      ".environment.stage.testing[].filepath"
    ],
    "data": [
      {
        "input": {
          "environment": {
            "stage": {
              "testing": [
                {
                  "tag": "1.0",
                  "filepath": "C:/test/conf",
                  "hostname": "test"
                }
              ]
            }
          }
        },
        "output": [
          "C:/test/conf"
        ]
      }
    ],
    "identifier": 51097759
  },
  {
    "context": [
      "... but if the unique value starts with a certain string (say, BAD-), I want to exclude the array member entirely.",
      "it would be nicer / more efficient to exclude this pattern within `jq` itself. How could that be accomplished?",
      "jq -r '.array[] |              select(.uniqV | startswith(\"BAD-\") | not) |             [.uniqV, .v1, .v2, .v3] |             @csv' something.json"
    ],
    "utterance": "Extract selected fields from each element of an array as CSV, excluding those where uniqV starts with BAD-.",
    "expressions": [
      ".array[] | select(.uniqV | startswith(\"BAD-\") | not) | [.uniqV, .v1, .v2, .v3] | @csv"
    ],
    "identifier": 51099819
  },
  {
    "context": [
      "How to get the proprety name `foo` from `\"Name 2\"` using jq ?",
      "jq 'path(recurse|select(.name?==\"Name 2\"))[0]' file.json"
    ],
    "utterance": "Find the top-level object key whose nested object contains a 'name' property with the value 'Name 2'.",
    "expressions": [
      "path(recurse|select(.name?==\"Name 2\"))[0]"
    ],
    "data": [
      {
        "input": {
          "foo": {
            "name": "Name 1",
            "color": "green",
            "something_else": {
              "name": "Name 2"
            }
          },
          "bar": {
            "name": "Name 3",
            "color": "red"
          }
        },
        "output": "foo"
      }
    ],
    "identifier": 51103560
  },
  {
    "context": [
      "Want to parse the following:",
      "{ \"issues\": [ { \"id\": \"1\", \"fields\": { \"links\": [] } }, { \"id\": \"2\", \"fields\": { \"links\": [ { \"inlink\": { \"id\": \"red\" } } ] } }, { \"id\": \"3\", \"fields\": { \"links\": [ { \"outlink\": { \"id\": \"yellow\" } } ] } }, { \"id\": \"4\", \"fields\": { \"links\": [ { \"inlink\": { \"id\": \"green\" } }, { \"outlink\": { \"id\": \"blue\" } } ] } } ] }",
      "into elements that represent the `links` elements, one for one, like this (note that `id 1` is missing and `id 4` appears twice:",
      "{ \"id\": \"2\", \"link\": { \"linktype\": \"inlink\", \"id\": \"red\" } },",
      "{ \"id\": \"3\", \"link\": { \"linktype\": \"outlink\", \"id\": \"yellow\" } },",
      "{ \"id\": \"4\", \"link\": { \"linktype\": \"inlink\", \"id\": \"green\" } },",
      "{ \"id\": \"4\", \"link\": { \"linktype\": \"outlink\", \"id\": \"blue\" } }",
      "jq -c '.issues[] | .id as $id\n       | .fields.links[] | to_entries[]\n       | {\"id\": $id, \"link\": {\"linktype\": .key, \"id\": .value.id}}' file",
      "The output:",
      "{\"id\":\"2\",\"link\":{\"linktype\":\"inlink\",\"id\":\"red\"}}",
      "{\"id\":\"3\",\"link\":{\"linktype\":\"outlink\",\"id\":\"yellow\"}}",
      "{\"id\":\"4\",\"link\":{\"linktype\":\"inlink\",\"id\":\"green\"}}",
      "{\"id\":\"4\",\"link\":{\"linktype\":\"outlink\",\"id\":\"blue\"}}"
    ],
    "utterance": "Output objects for each link with the parent issue's id and a nested object containing the link type and id, omitting issues where links are empty.",
    "expressions": [
      ".issues[] | .id as $id | .fields.links[] | to_entries[] | {\"id\": $id, \"link\": {\"linktype\": .key, \"id\": .value.id}}"
    ],
    "data": [
      {
        "input": {
          "issues": [
            {
              "id": "1",
              "fields": {
                "links": []
              }
            },
            {
              "id": "2",
              "fields": {
                "links": [
                  {
                    "inlink": {
                      "id": "red"
                    }
                  }
                ]
              }
            },
            {
              "id": "3",
              "fields": {
                "links": [
                  {
                    "outlink": {
                      "id": "yellow"
                    }
                  }
                ]
              }
            },
            {
              "id": "4",
              "fields": {
                "links": [
                  {
                    "inlink": {
                      "id": "green"
                    }
                  },
                  {
                    "outlink": {
                      "id": "blue"
                    }
                  }
                ]
              }
            }
          ]
        },
        "output": [
          {
            "id": "2",
            "link": {
              "linktype": "inlink",
              "id": "red"
            }
          },
          {
            "id": "3",
            "link": {
              "linktype": "outlink",
              "id": "yellow"
            }
          },
          {
            "id": "4",
            "link": {
              "linktype": "inlink",
              "id": "green"
            }
          },
          {
            "id": "4",
            "link": {
              "linktype": "outlink",
              "id": "blue"
            }
          }
        ]
      }
    ],
    "identifier": 51093319
  },
  {
    "context": [
      "How can I recursively rename all \"groups\" to say \"newGroups\" and \"items\" to \"newItems\"?",
      "I've used the following filter in my script",
      "def walk(f):\n  . as $in\n  | if type == \"object\" then\n      reduce keys_unsorted[] as $key\n        ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\n  elif type == \"array\" then map( walk(f) ) | f\n  else f\n  end;\n \ndef translate_keys(f):\n  walk( if type == \"object\" then\n            with_entries( if .key | contains(\"groups\") then\n                             .key |= \"newgroups\"\n                          elif .key | contains(\"items\") then\n                             .key |= \"newitems\"\n                          else\n                             . end\n                        )\n        else\n            . end\n      );\n \n \ntranslate_keys(.)",
      "walk(if type == \"object\" and has(\"groups\")\n     then .newGroups = .groups | del(.groups)\n     | walk(if type == \"object\" and has(\"items\")\n            then .newItems = .items | del(.items)\n            else . end)\n     else . end)"
    ],
    "utterance": "Recursively rename all keys named \"groups\" to \"newGroups\" and all keys named \"items\" to \"newItems\" at every level of nesting.",
    "expressions": [
      "def walk(f):\n  . as $in\n  | if type == \"object\" then\n      reduce keys_unsorted[] as $key\n        ( {}; . + { ($key):  ($in[$key] | walk(f)) } ) | f\n  elif type == \"array\" then map( walk(f) ) | f\n  else f\n  end;\ndef translate_keys(f):\n  walk( if type == \"object\" then\n            with_entries( if .key == \"groups\" then\n                             .key |= \"newGroups\"\n                          elif .key == \"items\" then\n                             .key |= \"newItems\"\n                          else\n                             . end\n                        )\n        else\n            . end\n      );\ntranslate_keys(.)",
      "walk(if type == \"object\" and has(\"groups\")\n     then .newGroups = .groups | del(.groups)\n     | walk(if type == \"object\" and has(\"items\")\n            then .newItems = .items | del(.items)\n            else . end)\n     else . end)"
    ],
    "data": [
      {
        "input": {
          "groups": [
            {
              "name": "group1",
              "items": [
                {
                  "name": "item1",
                  "groups": [
                    {
                      "name": "nestedGroup1",
                      "items": [
                        {
                          "name": "nestedItem1",
                          "groups": []
                        },
                        {
                          "name": "nestedItem2",
                          "groups": []
                        }
                      ]
                    }
                  ]
                },
                {
                  "name": "item2",
                  "groups": []
                }
              ]
            }
          ]
        },
        "output": {
          "newGroups": [
            {
              "name": "group1",
              "newItems": [
                {
                  "name": "item1",
                  "newGroups": [
                    {
                      "name": "nestedGroup1",
                      "newItems": [
                        {
                          "name": "nestedItem1",
                          "newGroups": []
                        },
                        {
                          "name": "nestedItem2",
                          "newGroups": []
                        }
                      ]
                    }
                  ]
                },
                {
                  "name": "item2",
                  "newGroups": []
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 51091583
  },
  {
    "context": [
      "I want to get output like this:",
      "\"Bestco\",1\n\"GreatCo\",2\n\"DressCo\",3",
      "How do I do this with just jq.",
      "jq -r '.things[] | [.thing_name, .thing_id] | @csv' <<<\"$s\"",
      "...properly emits:",
      "\"Bestco\",1\n\"GreatCo\",2\n\"DressCo\",3"
    ],
    "utterance": "Output each object's thing_name and thing_id as a CSV line.",
    "expressions": [
      ".things[] | [.thing_name, .thing_id] | @csv"
    ],
    "data": [
      {
        "input": {
          "things": [
            {
              "thing_name": "Bestco",
              "thing_id": 1
            },
            {
              "thing_name": "GreatCo",
              "thing_id": 2
            },
            {
              "thing_name": "DressCo",
              "thing_id": 3
            }
          ]
        },
        "output": "\"Bestco\",1\n\"GreatCo\",2\n\"DressCo\",3"
      }
    ],
    "identifier": 51127531
  },
  {
    "context": [
      "So, on <<<<<<<<<<<<<(1)>>>>>>>>>>>>>> I need to aggregate each `key` and `value` propagation.",
      "So, in this case I'd need to generate: \"VAR1\": \"VAL1\", \"VAR2\": \"VAL2\", \"VAR3\": \"VAL3\" and then insert it inside \"stringData\":",
      "while read -r key value; do",
      "    json=$(echo \"$json\" | jq \".stringData += { \\\"$key\\\" : \\\"$value\\\" }\")",
      "done< <(awk -F= '!($1 && $2 && NF==2) { print \"File failed validation on line \" NR | \"cat 1>&2\"; next } { print $1, $2 }' $f)"
    ],
    "utterance": "Aggregate a list of key-value pairs into an object under the stringData field of a larger document, with each pair as a property.",
    "expressions": [
      ".stringData += { \"$key\" : \"$value\" }"
    ],
    "identifier": 51130649
  },
  {
    "context": [
      "I\u2019m trying to sort by `region`.",
      "jq -sc 'sort_by(.settings.region)[]' testout.out",
      "If your `testout.out` file would be as follows:\n\n    { \"_id\" : \"ObjectId(\\\"5aaaa017e4b09780301b6c18\\\")\", \"account\" : \"abc\", \"profile\" : \"catch\", \"settings\" : { \"region\" : \"us-east-1\" } }\n    { \"_id\" : \"ObjectId(\\\"5ad894fbe4b0657c569ed5d8\\\")\", \"account\" : \"def\", \"profile\" : \"test\", \"settings\" : { \"region\" : \"eu-central-1\" } }\n    { \"_id\" : \"ObjectId(\\\"5ae127dee4b06990170a0eb4\\\")\", \"account\" : \"ght\", \"profile\" : \"main\", \"settings\" : { \"region\" : \"us-east-1\" } }",
      "you\u2019ll be able to perform the needed sorting:"
    ],
    "utterance": "Sort a list of objects by the value of settings.region in ascending (alphabetical) order.",
    "expressions": [
      "jq -sc 'sort_by(.settings.region)[]' testout.out"
    ],
    "data": [
      {
        "input": [
          {
            "_id": "ObjectId(\"5aaaa017e4b09780301b6c18\")",
            "account": "abc",
            "profile": "catch",
            "settings": {
              "region": "us-east-1"
            }
          },
          {
            "_id": "ObjectId(\"5ad894fbe4b0657c569ed5d8\")",
            "account": "def",
            "profile": "test",
            "settings": {
              "region": "eu-central-1"
            }
          },
          {
            "_id": "ObjectId(\"5ae127dee4b06990170a0eb4\")",
            "account": "ght",
            "profile": "main",
            "settings": {
              "region": "us-east-1"
            }
          }
        ],
        "output": [
          {
            "_id": "ObjectId(\"5ad894fbe4b0657c569ed5d8\")",
            "account": "def",
            "profile": "test",
            "settings": {
              "region": "eu-central-1"
            }
          },
          {
            "_id": "ObjectId(\"5aaaa017e4b09780301b6c18\")",
            "account": "abc",
            "profile": "catch",
            "settings": {
              "region": "us-east-1"
            }
          },
          {
            "_id": "ObjectId(\"5ae127dee4b06990170a0eb4\")",
            "account": "ght",
            "profile": "main",
            "settings": {
              "region": "us-east-1"
            }
          }
        ]
      }
    ],
    "identifier": 51125135
  },
  {
    "context": [
      "Is it possible to slurp the result of the `split` without piping the result into a new instance of `jq`?",
      "echo -e \"a 1\\nb 2\" | jq -sR 'split(\"\\n\")[:-1] | map(split(\" \"))'",
      "$ echo -e \"a 1\\nb 2\" | jq -nR '[inputs|split(\" \")]'"
    ],
    "utterance": "Produce a single array of arrays where each sub-array contains the space-separated values from each line of the input.",
    "expressions": [
      "split(\"\\n\")[:-1] | map(split(\" \"))",
      "[inputs|split(\" \")]"
    ],
    "data": [
      {
        "input": "a 1\nb 2",
        "output": [
          [
            "a",
            "1"
          ],
          [
            "b",
            "2"
          ]
        ]
      }
    ],
    "identifier": 51132530
  },
  {
    "context": [
      "Now I want to apply regex to filter the property value, say I want to consider only all properties called `name` that have a value beginning with \"Name\" and followed by a number like `\"Name 2\"`, to get:\r\n\r\n    \"foo\"\r\n    \"foo\"",
      "paths(select(.name? | match(\"Name [0-9]\")))[0]"
    ],
    "utterance": "List the parent keys of all properties called 'name' whose value begins with 'Name' followed by a number.",
    "expressions": [
      "paths(select(.name? | match(\"Name [0-9]\")))[0]"
    ],
    "data": [
      {
        "input": {
          "foo": {
            "name": "Name 1",
            "color": "green",
            "something_else": {
              "name": "Name 2"
            }
          },
          "bar": {
            "name": "Something else",
            "color": "red"
          }
        },
        "output": [
          "foo",
          "foo"
        ]
      }
    ],
    "identifier": 51132305
  },
  {
    "context": [
      "I have a text file with  following values in \r\ninput.txt\r\n\r\n    key1=value1\\r\r\n    key2=value2\r\n    key3=value3\\r\r\n    key4=value4\r\n\r\n\r\nneed the jq rexpression to convert it to  below json format  by removing &quot;\\r&quot; also\r\n\r\noutput.json\r\n\r\n    {\r\n\t&quot;Environment&quot;: {\r\n\t\t&quot;Variables&quot;: {\r\n\t\t\t&quot;key1&quot;: &quot;value1&quot;,\r\n\t\t\t&quot;key2&quot;: &quot;value2&quot;,\r\n\t\t\t&quot;key3&quot;: &quot;value3&quot;,\r\n\t\t\t&quot;key4&quot;: &quot;value4&quot;\r\n\t\t}\r\n\t}\r\n}",
      "jq -sR '{\"Environment\":\n                {\"Variables\": [split(\"\\n\")[:-1][] | rtrimstr(\"\\\\r\") \n                                 | split(\"=\") | {(.[0]): .[1]}\n                              ]  | add\n                }\n            }' input.txt",
      "[inputs | sub(\"\\\\r$\";\"\") | capture(\"^(?<key>[^=]*)=(?<value>.*)\")]\n| from_entries\n| {Environment: { Variables: .}}"
    ],
    "utterance": "Transform a text file containing lines of key=value pairs (some with trailing carriage returns) into an object nested under Environment.Variables, with each key and value mapped correctly and all trailing '\\r' characters removed.",
    "expressions": [
      "jq -sR '{\"Environment\": {\"Variables\": [split(\"\\n\")[:-1][] | rtrimstr(\"\\r\") | split(\"=\") | {(.[0]): .[1]} ] | add }}' input.txt",
      "[inputs | sub(\"\\r$\"; \"\") | capture(\"^(?<key>[^=]*)=(?<value>.*)\")]\n| from_entries\n| {Environment: { Variables: .}}"
    ],
    "data": [
      {
        "input": "key1=value1\r\nkey2=value2\nkey3=value3\r\nkey4=value4\n",
        "output": {
          "Environment": {
            "Variables": {
              "key1": "value1",
              "key2": "value2",
              "key3": "value3",
              "key4": "value4"
            }
          }
        }
      }
    ],
    "identifier": 51115902
  },
  {
    "context": [
      "Requirement:  To recursively identify arrays [] that only contain a single object {} and to convert the array back to a standard object {}.  Essentially to strip out the parent array when its not needed.",
      "What seems to be working:",
      "(..|select(type==\"array\" and .[1] == null ) | . ) |= add | .",
      "The simplest approach is to use walk/1, which however was only introduced after the release of jq 1.5.  The following therefore includes its definition:",
      "walk(if type==\"array\" and length==1 and (.[0]|type) == \"object\" then .[0] else . end)"
    ],
    "utterance": "Recursively replace arrays containing a single object with that object throughout the input.",
    "expressions": [
      "walk(if type==\"array\" and length==1 and (.[0]|type) == \"object\" then .[0] else . end)"
    ],
    "identifier": 51157550
  },
  {
    "context": [
      "I want to add `\"x3\": \"x3Val\",\"x4\": \"x4Val\"` to `x`. So the output should be",
      "jq '.x += {\"x3\": \"x3Val\",\"x4\": \"x4Val\"}' file.json",
      "$ jq '.x.x3=\"x3val\"|.x.x4=\"x4val\"' file",
      "jq --arg v3 \"x3val\" --arg v4 \"x4val\" '.x.x3=$v3|.x.x4=$v4' file"
    ],
    "utterance": "Add key-value pairs x3: x3Val and x4: x4Val to the x object inside the data structure.",
    "expressions": [
      ".x += {\"x3\": \"x3Val\",\"x4\": \"x4Val\"}",
      ".x.x3=\"x3Val\"|.x.x4=\"x4Val\"",
      ".x.x3=$v3|.x.x4=$v4"
    ],
    "data": [
      {
        "input": {
          "a": "aVal",
          "x": {
            "x1": "x1Val",
            "x2": "x2Val"
          },
          "y": {
            "y1": "y1Val"
          }
        },
        "output": {
          "a": "aVal",
          "x": {
            "x1": "x1Val",
            "x2": "x2Val",
            "x3": "x3Val",
            "x4": "x4Val"
          },
          "y": {
            "y1": "y1Val"
          }
        }
      }
    ],
    "identifier": 51147753
  },
  {
    "context": [
      "I need to generate a flatter JSON file and combine the users and groups into one field, similar to this:",
      "[ { \"id\": 100, \"users_groups\": [ \"admin_1\", \"admin_2\" ], \"bar\": [\"read\"] }, ... ]",
      "Everything I try in JQ results in me getting an incorrect output (where admin_1 incorrectly has bar=execute and admin_2 incorrectly has bar=write), similar to the following:",
      "cat file.json | jq -r '[.[] | select(has(\"foo\")) |{\"id\", \"users\":(.foo[] | .users), \"groups\":(.foo[] | .groups), \"bar\":([.foo[].bar[] | .type])} ] '",
      "The following filter groups by \"type\" as the question seems to require:",
      "map(.id as $id | [.foo[] | {id: $id, bar: .bar[].type} + {\"users_groups\": (.users + .groups)[]} ] | group_by(.bar) | map(.[0] + {\"users_groups\": [.[].users_groups]}) )",
      "To achieve the array-of-objects output format, simply tack on `| [.[][]]`;"
    ],
    "utterance": "Produce a flat object for each unique id and bar type, combining related users and groups into a single users_groups array, matching specific user/group to bar association without incorrect cross-pairing.",
    "expressions": [
      "map(.id as $id | [.foo[] | {id: $id, bar: .bar[].type} + {\"users_groups\": (.users + .groups)[]} ] | group_by(.bar) | map(.[0] + {\"users_groups\": [.[].users_groups]}) ) | [.[][]]"
    ],
    "data": [
      {
        "input": [
          {
            "id": 100,
            "foo": [
              {
                "bar": [
                  {
                    "type": "read"
                  },
                  {
                    "type": "write"
                  }
                ],
                "users": [
                  "admin_1"
                ],
                "groups": []
              },
              {
                "bar": [
                  {
                    "type": "execute"
                  },
                  {
                    "type": "read"
                  }
                ],
                "users": [],
                "groups": [
                  "admin_2"
                ]
              }
            ]
          },
          {
            "id": 101,
            "foo": [
              {
                "bar": [
                  {
                    "type": "read"
                  }
                ],
                "users": [
                  "admin_3"
                ],
                "groups": []
              }
            ]
          }
        ],
        "output": [
          {
            "id": 100,
            "bar": "execute",
            "users_groups": [
              "admin_2"
            ]
          },
          {
            "id": 100,
            "bar": "read",
            "users_groups": [
              "admin_1",
              "admin_2"
            ]
          },
          {
            "id": 100,
            "bar": "write",
            "users_groups": [
              "admin_1"
            ]
          },
          {
            "id": 101,
            "bar": "read",
            "users_groups": [
              "admin_3"
            ]
          }
        ]
      }
    ],
    "identifier": 51137733
  },
  {
    "context": [
      "for id=319 user=foo should have access consume and create, and group=bar should have have access publish and create.",
      "My expected output would be something like this where users and groups are combined and correctly show the correct access.",
      "I think you want something like this:",
      "jq -n '[inputs | .id as $id | .policyItems[] | {\"id\": $id, \"access_type\": (reduce .accesses[].type as $item ([]; . + [$item])), \"users_groups\": (.users + .groups)}]'",
      "And we finally combine the \"users\" and \"groups\" arrays into one single array"
    ],
    "utterance": "For each id and policy item, list the id, all accesses types, and combine users and groups into a single users_groups array.",
    "expressions": [
      "jq -n '[inputs | .id as $id | .policyItems[] | {\"id\": $id, \"access_type\": (reduce .accesses[].type as $item ([]; . + [$item])), \"users_groups\": (.users + .groups)}]'"
    ],
    "data": [
      {
        "input": [
          {
            "id": 319,
            "policyItems": [
              {
                "accesses": [
                  {
                    "type": "consume",
                    "isAllowed": true
                  },
                  {
                    "type": "create",
                    "isAllowed": true
                  }
                ],
                "users": [
                  "foo"
                ],
                "groups": []
              },
              {
                "accesses": [
                  {
                    "type": "publish",
                    "isAllowed": true
                  },
                  {
                    "type": "create",
                    "isAllowed": true
                  }
                ],
                "users": [],
                "groups": [
                  "bar"
                ]
              }
            ]
          },
          {
            "id": 320,
            "policyItems": [
              {
                "accesses": [
                  {
                    "type": "publish",
                    "isAllowed": true
                  },
                  {
                    "type": "create",
                    "isAllowed": true
                  }
                ],
                "users": [
                  "foo"
                ],
                "groups": []
              },
              {
                "accesses": [
                  {
                    "type": "consume",
                    "isAllowed": true
                  },
                  {
                    "type": "create",
                    "isAllowed": true
                  }
                ],
                "users": [],
                "groups": [
                  "bar"
                ]
              }
            ]
          }
        ],
        "output": [
          {
            "id": 319,
            "access_type": [
              "consume",
              "create"
            ],
            "users_groups": [
              "foo"
            ]
          },
          {
            "id": 319,
            "access_type": [
              "publish",
              "create"
            ],
            "users_groups": [
              "bar"
            ]
          },
          {
            "id": 320,
            "access_type": [
              "publish",
              "create"
            ],
            "users_groups": [
              "foo"
            ]
          },
          {
            "id": 320,
            "access_type": [
              "consume",
              "create"
            ],
            "users_groups": [
              "bar"
            ]
          }
        ]
      }
    ],
    "identifier": 51051719
  },
  {
    "context": [
      "arrayA have Line_Number SS001. Find this Line_Number in json and compare Service_Type value and Status value are same or not.",
      "jq --arg Line_Number SS001 --arg Status Yes '\n  .tbl_am_api\n  | map(select(.Line_Number==$Line_Number and .Status==$Status)) '",
      "jq --arg Line_Number SS001 --arg Status Yes '\n  .tbl_am_api\n  | map(select(.Line_Number==$Line_Number) | .Status==$Status) '"
    ],
    "utterance": "Find entries where Line_Number is SS001 and Status is Yes and output them.",
    "expressions": [
      ".tbl_am_api | map(select(.Line_Number==$Line_Number and .Status==$Status))",
      ".tbl_am_api | map(select(.Line_Number==$Line_Number) | .Status==$Status)"
    ],
    "data": [
      {
        "input": {
          "tbl_am_api": [
            {
              "Modified_User": "user1",
              "Modified_Time": "04-Jul-2018 01:40:05",
              "Line_Number": "SS001",
              "Service_Type": "BB3",
              "Status": "Yes",
              "ID": 3144526000014337832,
              "Added_Time": "04-May-2018 11:37:29"
            },
            {
              "Modified_User": "user2",
              "Modified_Time": "04-Jul-2018 01:40:05",
              "Line_Number": "SS002",
              "Service_Type": "BB2",
              "Status": "Yes",
              "ID": 3144526000014337832,
              "Added_Time": "04-May-2018 11:37:29"
            },
            {
              "Modified_User": "user3",
              "Modified_Time": "04-Jul-2018 01:40:05",
              "Line_Number": "SS004",
              "Service_Type": "BB1",
              "Status": "No",
              "ID": 3144526000014337832,
              "Added_Time": "04-May-2018 11:37:29"
            }
          ]
        },
        "output": [
          {
            "Modified_User": "user1",
            "Modified_Time": "04-Jul-2018 01:40:05",
            "Line_Number": "SS001",
            "Service_Type": "BB3",
            "Status": "Yes",
            "ID": 3144526000014337832,
            "Added_Time": "04-May-2018 11:37:29"
          }
        ]
      }
    ],
    "identifier": 51183360
  },
  {
    "context": [
      "here the array subThings is empty",
      "$ echo '[{\"thing-1\" : \"meta1\",\"thing-2\" : \"meta2\",\"thing-n\" : \"metan\",\"subThings\":[]}]' | jq '[.[] | {\"thing-1\",\"thing-5\",\"subThing-2\":.subThings[][\"subThing-2\"],}]'",
      "[]",
      "You need to evaluate the `subThings` separately and replace with `null` if there are none, otherwise it will just simply be `empty` which yields nothing (which is what you're seeing here).",
      "map({ \"thing-1\", \"thing-5\", \"subThing-2\": (.subThings[].\"subThing-2\" // null) })"
    ],
    "utterance": "Produce an object for each item, including the value of thing-1, thing-5, and the subThing-2 from each subThings element, and if subThings is empty, set subThing-2 to null.",
    "expressions": [
      "map({ \"thing-1\", \"thing-5\", \"subThing-2\": (.subThings[].\"subThing-2\" // null) })",
      "[.[] | {\"thing-1\", \"thing-5\", \"subThing-2\": (.subThings[].\"subThing-2\" // null)}]"
    ],
    "data": [
      {
        "input": [
          {
            "thing-1": "meta1",
            "thing-2": "meta2",
            "thing-n": "metan",
            "subThings": [
              {
                "subThing-1": "subMeta1",
                "subThing-2": "subMeta2",
                "subThing-n": "subMetan"
              }
            ]
          }
        ],
        "output": [
          {
            "thing-1": "meta1",
            "thing-5": null,
            "subThing-2": "subMeta2"
          }
        ]
      },
      {
        "input": [
          {
            "thing-1": "meta1",
            "thing-2": "meta2",
            "thing-n": "metan",
            "subThings": []
          }
        ],
        "output": [
          {
            "thing-1": "meta1",
            "thing-5": null,
            "subThing-2": null
          }
        ]
      }
    ],
    "identifier": 51160906
  },
  {
    "context": [
      "cat priv.json | jq '.data | map(select(.properties | any(.[]; .value == \"$1\")) |.id)[0]'",
      "JSON file (priv.json) is below: { \"data\": [{ \"id\": \"abcd1g2f\", ... \"properties\": [{ ... { \"value\": \"client_release\" }, ... }]}, ... ] }",
      "command which i executed: ./test.sh client_release"
    ],
    "utterance": "Select the id of the first object in data where any property has a value equal to client_release.",
    "expressions": [
      ".data | map(select(.properties | any(.[]; .value == \"client_release\")) | .id)[0]"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": "abcd1g2f",
              "properties": [
                {
                  "key": "repositoryGroupId",
                  "value": ""
                },
                {
                  "key": "method",
                  "value": "create,read"
                },
                {
                  "key": "repositoryId",
                  "value": "client_release"
                },
                {
                  "key": "repositoryTargetId",
                  "value": "1"
                }
              ]
            },
            {
              "id": "asdf1k4g",
              "properties": [
                {
                  "key": "repositoryGroupId",
                  "value": ""
                },
                {
                  "key": "method",
                  "value": "read"
                },
                {
                  "key": "repositoryId",
                  "value": "formal_release"
                },
                {
                  "key": "repositoryTargetId",
                  "value": "1"
                }
              ]
            },
            {
              "id": "hirk5d7b3l",
              "properties": [
                {
                  "key": "repositoryGroupId",
                  "value": ""
                },
                {
                  "key": "method",
                  "value": "create,read"
                },
                {
                  "key": "repositoryId",
                  "value": "client_release"
                },
                {
                  "key": "repositoryTargetId",
                  "value": "1"
                }
              ]
            }
          ]
        },
        "output": "abcd1g2f"
      }
    ],
    "identifier": 51193201
  },
  {
    "context": [
      "I want to print ID of parent element when child element value is `client_release` from JSON data.",
      "if\n    data.properties.value== \"client_release\"\n\nthen output should be \n\n    abcd1g2f,hirk5d7b3l",
      "jq '.data[] | select(.properties[].value == \"client_release\") | .id'",
      "jq --raw-output '[.data[] | select(.properties[].value == \"client_release\") | .id] | @csv'",
      ".data\n| map(select(.properties | any(.[]; .value == \"client_release\")) | .id)\n| join(\",\")",
      ".data\n| map(select(.properties | from_entries.repositoryId == \"client_release\") | .id)\n| join(\",\")"
    ],
    "utterance": "Retrieve the ids of objects whose properties contain a value equal to client_release.",
    "expressions": [
      ".data[] | select(.properties[].value == \"client_release\") | .id",
      "[.data[] | select(.properties[].value == \"client_release\") | .id] | @csv",
      ".data | map(select(.properties | any(.[]; .value == \"client_release\")) | .id) | join(\",\")",
      ".data | map(select(.properties | from_entries.repositoryId == \"client_release\") | .id) | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": "abcd1g2f",
              "resourceURI": "https://somerepo.com/service/local/privileges/abcd1g2f",
              "name": "release1",
              "description": "release1",
              "type": "target",
              "userManaged": true,
              "properties": [
                {
                  "key": "repositoryGroupId",
                  "value": ""
                },
                {
                  "key": "method",
                  "value": "create,read"
                },
                {
                  "key": "repositoryId",
                  "value": "client_release"
                },
                {
                  "key": "repositoryTargetId",
                  "value": "1"
                }
              ]
            },
            {
              "id": "asdf1k4g",
              "resourceURI": "https://somerepo.com/service/local/privileges/asdf1k4g",
              "name": "release2",
              "description": "release2",
              "type": "target",
              "userManaged": true,
              "properties": [
                {
                  "key": "repositoryGroupId",
                  "value": ""
                },
                {
                  "key": "method",
                  "value": "read"
                },
                {
                  "key": "repositoryId",
                  "value": "formal_release"
                },
                {
                  "key": "repositoryTargetId",
                  "value": "1"
                }
              ]
            },
            {
              "id": "hirk5d7b3l",
              "resourceURI": "https://somerepo.com/service/local/privileges/hirk5d7b3l",
              "name": "release3",
              "description": "release3",
              "type": "target",
              "userManaged": true,
              "properties": [
                {
                  "key": "repositoryGroupId",
                  "value": ""
                },
                {
                  "key": "method",
                  "value": "create,read"
                },
                {
                  "key": "repositoryId",
                  "value": "client_release"
                },
                {
                  "key": "repositoryTargetId",
                  "value": "1"
                }
              ]
            }
          ]
        },
        "output": [
          "abcd1g2f",
          "hirk5d7b3l"
        ]
      }
    ],
    "identifier": 51184524
  },
  {
    "context": [
      "I wanted to join a json array around the non-displaying character `\\30` (\"RecordSeparator\") so I could safely iterate over it in bash, but I couldn't quite figure out how to do it. I tried `echo '[\"one\",\"two\",\"three\"]' | jq 'join(\"\\30\")'` and a couple permutations of that, but it didn't work.",
      "You simply use bash's `$'\\30'` syntax to insert the special character in-line, like so: `echo '[\"one\",\"two\",\"three\"]' | jq '. | join(\"'$'\\30'\")'`.",
      "[\"one\",\"two\",\"three\"] | jq --raw-output 'join(\"\\t\")' produces `one\ttwo\tthree` (with tab characters)"
    ],
    "utterance": "Join the elements of an array using a non-displaying character such as the record separator or tab as the delimiter.",
    "expressions": [
      ". | join(\"'$'\\30'\")",
      "join(\"\t\")",
      "join(\"\\u001e\")",
      "join(\"\\u0000\")"
    ],
    "data": [
      {
        "input": [
          "one",
          "two",
          "three"
        ],
        "output": "one\ttwo\tthree"
      }
    ],
    "identifier": 51228673
  },
  {
    "context": [
      "i want to extract the fileds group1.field0, group1.name,group2.field1, group1.field3",
      "the command i am running is below",
      "jq '.group0[].group1[]|\"\\(.name)|\\(.field0)|\\(.group2.field1)|\\(.group2.field3)\"' sample.json",
      "when i run the above command in Solaris it just hangs and does nothing.",
      "The following might well work: replace (.group2.field1) by (.group2|.field1) and similarly for (.group2.field2)"
    ],
    "utterance": "Extract each group1 item's name, field0, and from its group2, the fields field1 and field3, formatted as a pipe-separated string.",
    "expressions": [
      ".group0[].group1[] | \"\\(.name)|\\(.field0)|\\(.group2|.field1)|\\(.group2|.field3)\""
    ],
    "data": [
      {
        "input": {
          "group0": [
            {
              "id": 9,
              "href": "href1",
              "name": "Americas",
              "group1": [
                {
                  "id": 8,
                  "href": "href2",
                  "name": "Anguilla (UK)",
                  "type": "country",
                  "code": "ai",
                  "group2": {
                    "field1": 9,
                    "field2": 1,
                    "field3": 1
                  }
                },
                {
                  "id": 9,
                  "href": "href3",
                  "name": "Antigua and Barbuda",
                  "type": "country",
                  "code": "ag",
                  "group2": {
                    "field1": 9,
                    "field2": 1,
                    "field3": 2
                  }
                },
                {
                  "id": 10,
                  "href": "href4",
                  "name": "Argentina",
                  "type": "country",
                  "code": "ar",
                  "group2": {
                    "field1": 8,
                    "field2": 1,
                    "field3": 2
                  },
                  "group3": [
                    {
                      "id": 599,
                      "href": "",
                      "name": "Rosario and Santa Fe (both Santa Fe province)",
                      "field3": 3
                    }
                  ]
                }
              ]
            },
            {
              "id": 10,
              "href": "href5",
              "name": "Asia & the Pacific",
              "group1": [
                {
                  "id": 1,
                  "href": "href6",
                  "name": "Afghanistan",
                  "type": "country",
                  "code": "af",
                  "group2": {
                    "field1": 10,
                    "field2": 3,
                    "field3": 5
                  }
                },
                {
                  "id": 14,
                  "href": "href7",
                  "name": "Australia",
                  "type": "country",
                  "code": "au",
                  "group2": {
                    "field1": 7,
                    "field2": 1,
                    "field3": 2
                  }
                },
                {
                  "id": 19,
                  "href": "href8",
                  "name": "Bangladesh",
                  "type": "country",
                  "code": "bd",
                  "group2": {
                    "field1": 9,
                    "field2": 2,
                    "field3": 3
                  },
                  "group3": [
                    {
                      "id": 216,
                      "href": "",
                      "name": "Chittagong Hill Tracts; Dhaka",
                      "field3": 4
                    }
                  ]
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 51200224
  },
  {
    "context": [
      "I want:\n\n    {\n        \"file1\": { \"roles\": [\"mysql\"] },\n        \"file2\": { \"roles\": [\"mysql\", \"php\"] }\n    }\n\nI do want the \".json\" file extension stripped too *if possible*, and just the basename (dir excluded).",
      "I'm trying to find files that contain \"mysql\" in their list of \"roles\". I need the filename and contents combined into one JSON object.",
      "jq 'if (.roles[] | contains(\"mysql\")) then {(input_filename | gsub(\".*/|\\\\.json$\";\"\") ): .}\n    else empty end' ./file1.json ./file2.json | jq -s 'add'",
      "jq -n '\n  [inputs\n   | select(.roles and any(.roles[]; contains(\"mysql\")))\n   | {(input_filename | gsub(\".*/|\\\\.json$\";\"\") ): .}]\n  | add' file*.json"
    ],
    "utterance": "Create an object mapping each file basename (filename without path or .json extension) to its content, only if its 'roles' array contains the value 'mysql'.",
    "expressions": [
      "jq 'if (.roles[] | contains(\"mysql\")) then {(input_filename | gsub(\".*/|\\\\.json$\";\"\") ): .} else empty end' ./file1.json ./file2.json | jq -s 'add'",
      "jq -n '[inputs | select(.roles and any(.roles[]; contains(\"mysql\"))) | {(input_filename | gsub(\".*/|\\\\.json$\";\"\") ): .}] | add' file*.json"
    ],
    "data": [
      {
        "input": {
          "file1.json": {
            "roles": [
              "mysql"
            ]
          },
          "file2.json": {
            "roles": [
              "mysql",
              "php"
            ]
          },
          "file3.json": {}
        },
        "output": {
          "file1": {
            "roles": [
              "mysql"
            ]
          },
          "file2": {
            "roles": [
              "mysql",
              "php"
            ]
          }
        }
      }
    ],
    "identifier": 51217020
  },
  {
    "context": [
      "I want to be able to parse the value `https://www.mycompany.com/api/nodes/node-aa5a5a55` from the `links` array where the `rel` value is `node`.  How can I construct a `jq` filter to achieve this?",
      "jq -r '.links | map(select(.rel=\"node\") | .href ) | first'",
      "jq -r '.links[] | select(.rel == \"node\") .href'"
    ],
    "utterance": "Extract the href value from elements in the links array where rel equals node.",
    "expressions": [
      ".links | map(select(.rel==\"node\") | .href ) | first",
      ".links[] | select(.rel == \"node\") .href"
    ],
    "data": [
      {
        "input": {
          "href": "https://www.mycompany.com/api/services/myservice/instances/service-instance-3",
          "id": "si-555aa555a555",
          "links": [
            {
              "rel": "node",
              "href": "https://www.mycompany.com/api/nodes/node-aa5a5a55"
            }
          ]
        },
        "output": "https://www.mycompany.com/api/nodes/node-aa5a5a55"
      }
    ],
    "identifier": 51259744
  },
  {
    "context": [
      "What I would like to do is remove the object where the checkId = \"201805111305QIN0A-TQCYEITA\" and make my file look like this:",
      "I was able to delete the desired object, but **the output of the jq command does not preserve the structure of my JSON file**",
      "Instead of `del` you could use `map(select(..))`, excluding the part you need.",
      "jq '.data |= map(select(.checkId != \"201805111305QIN0A-TQCYEITA\"))'",
      "Or using your actual `del` command, doing the reverse of above",
      "jq 'del(.data[] | select(.checkId == \"201805111305QIN0A-TQCYEITA\"))'"
    ],
    "utterance": "Remove the object with checkId equal to 201805111305QIN0A-TQCYEITA from the data array while preserving the original structure.",
    "expressions": [
      ".data |= map(select(.checkId != \"201805111305QIN0A-TQCYEITA\"))",
      "del(.data[] | select(.checkId == \"201805111305QIN0A-TQCYEITA\"))"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "subId": "201805111305QIN0A",
              "checkId": "201805111305QIN0A-CPIFK5ZG"
            },
            {
              "subId": "201805111305QIN0A",
              "checkId": "201805111305QIN0A-F7HGMZUV"
            },
            {
              "subId": "201805111305QIN0A",
              "checkId": "201805111305QIN0A-TQCYEITA"
            },
            {
              "subId": "201805111323U8B1D",
              "checkId": "201805111323U8B1D-HO648V2L"
            }
          ]
        },
        "output": {
          "data": [
            {
              "subId": "201805111305QIN0A",
              "checkId": "201805111305QIN0A-CPIFK5ZG"
            },
            {
              "subId": "201805111305QIN0A",
              "checkId": "201805111305QIN0A-F7HGMZUV"
            },
            {
              "subId": "201805111323U8B1D",
              "checkId": "201805111323U8B1D-HO648V2L"
            }
          ]
        }
      }
    ],
    "identifier": 51248893
  },
  {
    "context": [
      "Now I'm a little stuck trying to figure out which of the two JSON objects is the most recent.  How can I sort by date and extract the id for that object?",
      "The filter `sort_by/1` will sort your timestamps in chronological order, but it requires an array as input, so you could write:",
      ".items \n| map({ \"id\" : .id,  \"date\" : (.path |  scan(\"[0-9]{8}\\\\.[0-9-]*\")) })\n| sort_by(.date)\n| .[-1]",
      "The trailing `.[-1]` selects the last item, so with your input the result would be:",
      "{\n  \"id\": \"V0FEQS1TbmFwc2hvdHM6MzhjZDQ3NTQwMTBkNGJhOWM4YjQ0NmRjYzFkODkxM2U\",\n  \"date\": \"20180703.204941-2\"\n}"
    ],
    "utterance": "Extract the id and date of the artifact with the most recent date from the items array, where the date is the timestamp string within the path field.",
    "expressions": [
      ".items | map({ \"id\": .id, \"date\": (.path | scan(\"[0-9]{8}\\.[0-9-]*\")) }) | sort_by(.date) | .[-1]"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "downloadUrl": "https://nexus.ama.org/repository/Snapshots/org/sso/browser-manager/1.0-SNAPSHOT/browser-manager-1.0-20180703.144121-1.jar",
              "path": "org/sso/browser-manager/1.0-SNAPSHOT/browser-manager-1.0-20180703.144121-1.jar",
              "id": "V0FEQS1TbmFwc2hvdHM6MzhjZDQ3NTQwMTBkNGJhOTY1N2JiOTEyMTM1ZGRjZWQ",
              "repository": "Snapshots",
              "format": "maven2",
              "checksum": {
                "sha1": "7ac324905fb1ff15ef6020f256fcb5c9f54113ca",
                "md5": "bb25c483a183001dfdc58c07a71a98ed"
              }
            },
            {
              "downloadUrl": "https://nexus.ama.org/repository/Snapshots/org/sso/browser-manager/1.0-SNAPSHOT/browser-manager-1.0-20180703.204941-2.jar",
              "path": "org/sso/browser-manager/1.0-SNAPSHOT/browser-manager-1.0-20180703.204941-2.jar",
              "id": "V0FEQS1TbmFwc2hvdHM6MzhjZDQ3NTQwMTBkNGJhOWM4YjQ0NmRjYzFkODkxM2U",
              "repository": "Snapshots",
              "format": "maven2",
              "checksum": {
                "sha1": "b4ba2049ea828391c720f49b6668a66a8b0bca9c",
                "md5": "6757c55c0e6d933dc90e398204cca966"
              }
            }
          ],
          "continuationToken": null
        },
        "output": {
          "id": "V0FEQS1TbmFwc2hvdHM6MzhjZDQ3NTQwMTBkNGJhOWM4YjQ0NmRjYzFkODkxM2U",
          "date": "20180703.204941-2"
        }
      }
    ],
    "identifier": 51214375
  },
  {
    "context": [
      "I want to filter the output of a `kubectl` command running in `--watch` mode to keep an eye on changes to a certain k8s annotation.",
      "`kubectl get pod my-pod --watch -o json | jq '.metadata.annotations[\"my-annotation\"]'`",
      "So i've tested your command and it works perfectly. You are however missing a quote at the end of your command.",
      "kubectl get pod nginx-5dfd5597bb-tp8h7 --watch -o json | jq '.metadata.name'"
    ],
    "utterance": "Print the value of the annotation with key 'my-annotation' from the metadata.annotations field for each update from a watched pod.",
    "expressions": [
      ".metadata.annotations[\"my-annotation\"]"
    ],
    "identifier": 51280969
  },
  {
    "context": [
      "how should I proceed to obtain the following output?",
      "I have some objects deeply in the JSON, and I want to remove all keys in those nested objects except `\"a\"` and `\"b\"`, and keep the original JSON structure.",
      "For simple top-level operations I was able to select subsets of objects with `{a:.a, b:.b}` or `{a,b}` syntax, but in the nested context I don't know how to proceed and preserve the JSON structure.",
      "walk( if type == \"object\" then {a,b} else . end )",
      "map({ k1 : [(.k1[]|{a,b})], k2 : [(.k2[]|{a,b})] })",
      "[.[]|{ k1 : [(.k1[]|{a,b})], k2 : [(.k2[]|{a,b})] }]"
    ],
    "utterance": "Remove all keys except 'a' and 'b' from deeply nested objects, preserving the original structure.",
    "expressions": [
      "walk( if type == \"object\" then {a,b} else . end )",
      "map({ k1 : [(.k1[]|{a,b})], k2 : [(.k2[]|{a,b})] })",
      "[.[]|{ k1 : [(.k1[]|{a,b})], k2 : [(.k2[]|{a,b})] }]"
    ],
    "data": [
      {
        "input": [
          {
            "k1": [
              {
                "a": 1,
                "b": 2,
                "c": 3,
                "d": 4,
                "e": 5,
                "f": 6
              }
            ],
            "k2": [
              {
                "a": 1,
                "b": 2,
                "c": 3,
                "d": 4,
                "e": 5,
                "f": 6
              }
            ]
          }
        ],
        "output": [
          {
            "k1": [
              {
                "a": 1,
                "b": 2
              }
            ],
            "k2": [
              {
                "a": 1,
                "b": 2
              }
            ]
          }
        ]
      }
    ],
    "identifier": 51264999
  },
  {
    "context": [
      "What I end up with is a series of 50 to 900 (depending on the use) JSON objects (one per space/room).",
      "What I'd like to do here is create a quick and dirty script that can then process this JSON file in a loop, pulling the keys in as variables (items.id = $id, items.title = $title, etc.) with the associated values from the file",
      "You don't need to _loop_ over the JSON objects here, using `jq`, you could just interpolate the variable inside each object and do your logic as needed.",
      "jq --raw-output '.items[] | \"\\(.id)|\\(.title)|\\(.isLocked)\"' json |",
      "while IFS=\"|\" read -r id title flag; do"
    ],
    "utterance": "Extract id, title, and isLocked fields from each object in the items array as separate values for use in a shell script.",
    "expressions": [
      ".items[] | \"\u001b[.id]|\\(.title)|\\(.isLocked)\"",
      "jq --raw-output '.items[] | \"\\(.id)|\\(.title)|\\(.isLocked)\"' json"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "id": "Y2lzY29zcGFyazovL3VzL1JPT00vNGY0Y2Q5NDAtN2JkZi0xMWU4LThiMjMtMTU0YzAyNTI0YzBh",
              "title": "(CISCO INTERNAL): FTB - CMS Opportunity",
              "type": "group",
              "isLocked": false,
              "lastActivity": "2018-06-29T21:05:55.994Z",
              "creatorId": "Y2lzY29zcGFyazovL3VzL1BFT1BMRS9kMWI3MDRhNS05ZmU0LTQ3MTYtOGY2Zi02OGEyNjVjZGQ5YzM",
              "created": "2018-06-29T20:59:27.316Z"
            },
            {
              "id": "Y2lzY29zcGFyazovL3VzL1JPT00vMTQxODk5MTAtN2JiYS0xMWU4LThiOWUtMjMwOWM4Y2NiYWMz",
              "title": "USU Cisco Webex EDU Program",
              "type": "group",
              "isLocked": true,
              "lastActivity": "2018-06-29T19:46:14.993Z",
              "creatorId": "Y2lzY29zcGFyazovL3VzL1BFT1BMRS8wZThjMzg3Yy0zNzc5LTRlYTEtYmY2My1mNzZmMDJkYzVjM2M",
              "created": "2018-06-29T16:32:56.609Z"
            },
            {
              "id": "Y2lzY29zcGFyazovL3VzL1JPT00vZjYyNDg1NjAtNzg5Yy0xMWU4LTlmYzItNGZhYzQwZWE4MTA4",
              "title": "Darren TeamSpace Space",
              "type": "group",
              "isLocked": false,
              "lastActivity": "2018-06-26T15:00:03.332Z",
              "teamId": "Y2lzY29zcGFyazovL3VzL1RFQU0vZWQ5Mzc1ZDAtZjE1MC0xMWU1LWFjNWUtNTNiMzQxMDkxMTU1",
              "creatorId": "Y2lzY29zcGFyazovL3VzL1BFT1BMRS83YTBkMTJiMS1lODMxLTRkNmItYTAzMS0xMDU4Y2UwOTAwZTU",
              "created": "2018-06-25T17:26:57.561Z"
            }
          ]
        },
        "output": [
          "Y2lzY29zcGFyazovL3VzL1JPT00vNGY0Y2Q5NDAtN2JkZi0xMWU4LThiMjMtMTU0YzAyNTI0YzBh|(CISCO INTERNAL): FTB - CMS Opportunity|false",
          "Y2lzY29zcGFyazovL3VzL1JPT00vMTQxODk5MTAtN2JiYS0xMWU4LThiOWUtMjMwOWM4Y2NiYWMz|USU Cisco Webex EDU Program|true",
          "Y2lzY29zcGFyazovL3VzL1JPT00vZjYyNDg1NjAtNzg5Yy0xMWU4LTlmYzItNGZhYzQwZWE4MTA4|Darren TeamSpace Space|false"
        ]
      }
    ],
    "identifier": 51247664
  },
  {
    "context": [
      "could you provide any other ways to join JSON files by key?",
      "here's one approach that assumes bash:\n\n    jq -n --argfile f1 <(jq -s . file1.json) --argfile f2 <(jq -s . file2.json) -f join.jq \n\nwhere join.jq is as above."
    ],
    "utterance": "Merge two lists of objects by matching 'key', combining their fields into a single object for each key.",
    "expressions": [
      "hashJoin($f1; $f2; .key)[]"
    ],
    "data": [
      {
        "input": [
          [
            {
              "key": "874102296-1",
              "que_lat": "40"
            },
            {
              "key": "874102296-2",
              "que_lat": "406790"
            }
          ],
          [
            {
              "key": "874102296-1",
              "in_time": "1530874104733",
              "latency": "12864258288242"
            },
            {
              "key": "874102296-2",
              "in_time": "1530874104746"
            }
          ]
        ],
        "output": [
          {
            "key": "874102296-1",
            "in_time": "1530874104733",
            "latency": "12864258288242",
            "que_lat": "40"
          },
          {
            "key": "874102296-2",
            "in_time": "1530874104746",
            "que_lat": "406790"
          }
        ]
      }
    ],
    "identifier": 51269833
  },
  {
    "context": [
      "I have to update a field with specific name that might occur on any level of JSON structure - and might not. Like with all *.description fields in JSON below:",
      "I need to update \"description\" value with some dummy value if only it has null value, but do not touch existing values and do not create new fields where they do not exist.",
      "So desired result in this case is:",
      ".a.b[0].description left untouched because it existed and was not null; .a.b[1].description and .a.description are forced to \"DUMMY DESCRIPTION\" because these field existed and were null; and .a.b[2] as well as root level left untouched because there was no description field at all.",
      "What\u2019s the correct approach to walk through entire JSON in this case?",
      "The answer is `walk`!",
      "walk(if type == \"object\" and has(\"description\") and .description == null\n     then .description = \"DUMMY DESCRIPTION\"\n     else . end)",
      "One option you could consider is using streams.",
      "fromstream(tostream | if length == 2 and .[0][-1] == \"description\"\n    then .[1] |= (. // $replacement)\n    else .\nend)"
    ],
    "utterance": "Replace all values of fields named 'description' that are null, at any level of nesting, with the string 'DUMMY DESCRIPTION', without creating new fields or modifying non-null values.",
    "expressions": [
      "walk(if type == \"object\" and has(\"description\") and .description == null then .description = \"DUMMY DESCRIPTION\" else . end)",
      "fromstream(tostream | if length == 2 and .[0][-1] == \"description\" then .[1] |= (. // \"DUMMY DESCRIPTION\") else . end)"
    ],
    "data": [
      {
        "input": {
          "a": {
            "b": [
              {
                "name": "b0",
                "description": "b0 has description"
              },
              {
                "name": "b1",
                "description": null
              },
              {
                "name": "b2"
              }
            ],
            "description": null
          },
          "s": "Some string value"
        },
        "output": {
          "a": {
            "b": [
              {
                "name": "b0",
                "description": "b0 has description"
              },
              {
                "name": "b1",
                "description": "DUMMY DESCRIPTION"
              },
              {
                "name": "b2"
              }
            ],
            "description": "DUMMY DESCRIPTION"
          },
          "s": "Some string value"
        }
      }
    ],
    "identifier": 51272561
  },
  {
    "context": [
      "A minimal sample causing me problems:",
      "{\r\n  \"E23763\": {\r\n    \"data\": \"information\"\r\n  }\r\n}",
      "But if I try to extract the first field, it fails criptically:\r\n\r\n    $ cat test.json | jq .E23763\r\n    jq: error: Invalid numeric literal at EOF at line 1, column 7 (while parsing '.E23763') at <top-level>, line 1:\r\n    .E23763\r\n    jq: 1 compile error",
      "The expected result would had been:\r\n\r\n    {\r\n      \"data\": \"information\"\r\n    }",
      "jq '[\"E23763\"]' test.json",
      "jq '.\"E23763\"' json",
      "Without the [], in this case it was the correct solution but try both nonetheless",
      "Basically the parser is buggy and treats `.E` as the beginning of a number."
    ],
    "utterance": "Extract the object at the top-level key 'E23763'.",
    "expressions": [
      ".[\"E23763\"]",
      ".\"E23763\""
    ],
    "data": [
      {
        "input": {
          "E23763": {
            "data": "information"
          }
        },
        "output": {
          "data": "information"
        }
      }
    ],
    "identifier": 51325368
  },
  {
    "context": [
      "This filter:\n\n    .versions[].columns[] | select(.type == \"varchar\" and .length < 255) | .length = 255\n\nUpdates my data how I'd like, but I want to get back the full file/input in the end, not just the columns that were modified. How can I do that?",
      "I don't want to delete the columns that don't match the `select` (just leave them unchanged)",
      "Simply update your `.columns` property:\n\n    .versions[].columns\n     |= map(if (.type == \"varchar\" and .length < 255) then .length = 255 else . end)\n"
    ],
    "utterance": "Increase all 'varchar' columns with length less than 255 to length 255, keeping all other data unchanged.",
    "expressions": [
      ".versions[].columns |= map(if (.type == \"varchar\" and .length < 255) then .length = 255 else . end)"
    ],
    "data": [
      {
        "input": {
          "versions": [
            {
              "columns": [
                {
                  "type": "varchar",
                  "length": 100,
                  "name": "foo"
                },
                {
                  "type": "varchar",
                  "length": 255,
                  "name": "bar"
                },
                {
                  "type": "int",
                  "length": 4,
                  "name": "baz"
                }
              ]
            }
          ]
        },
        "output": {
          "versions": [
            {
              "columns": [
                {
                  "type": "varchar",
                  "length": 255,
                  "name": "foo"
                },
                {
                  "type": "varchar",
                  "length": 255,
                  "name": "bar"
                },
                {
                  "type": "int",
                  "length": 4,
                  "name": "baz"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 51291542
  },
  {
    "context": [
      "I would like to iterate over the results' (\"b\", \"e\") arrays ([\"c\", \"d\"] and [\"f\", \"g\"]) and reuse that result of that query to search the second part of my tree (the \"h\" part), iterating of the arrays of the outcome and display those.",
      "So my complete result would look like this:\n\n    \"b\", \"c\", \"i\"\n    \"b\", \"c\", \"j'\n    \"b\", \"d\", \"k\"\n    \"e\", \"f\", \"l\"\n    \"e\", \"f\", \"m\"\n    \"e\", \"f\", \"n\"\n    \"e\", \"g\", \"o\"",
      "Consider first this filter:\n\n    (.a | keys_unsorted[]) as $k1\n    | (.a |.[$k1][]) as $k2\n    | (.h |.[$k2][]) as $k3\n    | [$k1, $k2, $k3]",
      "With your data, the invocation:\n\n    jq -c -f filter.jq input.json\n\nproduces:\n\n    [\"b\",\"c\",\"i\"]\n    [\"b\",\"c\",\"j\"]\n    [\"b\",\"d\",\"k\"]\n    [\"e\",\"f\",\"l\"]\n    [\"e\",\"f\",\"m\"]\n    [\"e\",\"f\",\"n\"]\n    [\"e\",\"g\",\"o\"]"
    ],
    "utterance": "List all combinations where for each key of 'a', each value is paired with its corresponding values in 'h', resulting in arrays of three elements.",
    "expressions": [
      "(.a | keys_unsorted[]) as $k1 | (.a | .[$k1][]) as $k2 | (.h | .[$k2][]) as $k3 | [$k1, $k2, $k3]"
    ],
    "data": [
      {
        "input": {
          "a": {
            "b": [
              "c",
              "d"
            ],
            "e": [
              "f",
              "g"
            ]
          },
          "h": {
            "c": [
              "i",
              "j"
            ],
            "d": [
              "k"
            ],
            "f": [
              "l",
              "m",
              "n"
            ],
            "g": [
              "o"
            ]
          }
        },
        "output": [
          [
            "b",
            "c",
            "i"
          ],
          [
            "b",
            "c",
            "j"
          ],
          [
            "b",
            "d",
            "k"
          ],
          [
            "e",
            "f",
            "l"
          ],
          [
            "e",
            "f",
            "m"
          ],
          [
            "e",
            "f",
            "n"
          ],
          [
            "e",
            "g",
            "o"
          ]
        ]
      }
    ],
    "identifier": 51284997
  },
  {
    "context": [
      "I\u2019m trying to convert the JSON output from AWS SSM to environment variables.",
      "note I\u2019m only after the environment variable AFTER the last /. There may be cases where this could be /qa/es/something/nested/ENV_VAR",
      "With the -r command-line option, .[] | \"\\(.Name|split(\"/\")|.[-1])=\\(.Value)\" yields: AWS_ACCESS_KEY_ID=ABC123 AWS_SECRET_ACCESS_KEY=abcdefghijkl ENDPOINT=https://amazonaws.com",
      "As the previous comment but use '@sh' to escape the value\n```.[]\n| \"\\(.Name|split(\"/\")|.[-1])=\\(.Value | @sh)\"```"
    ],
    "utterance": "Extract key/value pairs so that for each object, use only the segment after the last '/' from Name as the key, and print key=value for all pairs.",
    "expressions": [
      ".[] | \"\\(.Name|split(\"/\")|.[-1])=\\(.Value)\"",
      ".[] | \"\\(.Name|split(\"/\")|.[-1])=\\(.Value | @sh)\""
    ],
    "data": [
      {
        "input": [
          {
            "Name": "/qa/es/AWS_ACCESS_KEY_ID",
            "Value": "ABC123"
          },
          {
            "Name": "/qa/es/AWS_SECRET_ACCESS_KEY",
            "Value": "abcdefghijkl"
          },
          {
            "Name": "/qa/es/ENDPOINT",
            "Value": "https://amazonaws.com"
          }
        ],
        "output": [
          "AWS_ACCESS_KEY_ID=ABC123",
          "AWS_SECRET_ACCESS_KEY=abcdefghijkl",
          "ENDPOINT=https://amazonaws.com"
        ]
      }
    ],
    "identifier": 51331595
  },
  {
    "context": [
      "How do I specify colors other than the defaults used for [`jq --color-output`][1]?",
      "To configure alternative colors just set the `JQ_COLORS`  environment variable to colon-delimited list of partial terminal  escape sequences like `\"1;31\"`, in this order:",
      "The default color scheme is the same as setting  `\"JQ_COLORS=1;30:0;39:0;39:0;39:0;32:1;39:1;39\"`.",
      "The above example sets:\n\n - null: dim yellow\n - false: dim yellow\n - true: yellow\n - numbers: cyan\n - strings: bright green\n - arrays: magenta\n - objects: bright magenta\n - object _keys_: dim blue"
    ],
    "utterance": "Specify custom color codes for null, false, true, numbers, strings, arrays, objects, and optionally object keys in the colored output by configuring the environment variable.",
    "expressions": [
      "export JQ_COLORS=\"2;33:2;33:0;33:0;36:1;32:0;35:1;35:2;34\""
    ],
    "identifier": 51338701
  },
  {
    "context": [
      "If you want to access the `slug` property of each element of the array, you can do so like this:\r\n\r\n        jq '.[].slug' $IDENTIFIER.json",
      "If I take your sample json, remove the errant commas, save it to a plain text file called `test.json` and run the following command:\r\n\r\n    jq '.[].slug' test.json\r\n\r\nI get the following output:\r\n\r\n    \"foo\"\r\n    \"bar\"\r\n    \"mon\"\r\n    \"fort\"",
      "With the JSON in input.json:\r\n\r\n    $ jq -c 'map(.slug)' input.json\r\n    [\"foo\",\"bar\",\"mon\",\"fort\"]"
    ],
    "utterance": "Extract all slug values from each object in the array at the root of the data.",
    "expressions": [
      ".[].slug",
      "map(.slug)"
    ],
    "data": [
      {
        "input": [
          {
            "id": 4,
            "count": 18,
            "description": "",
            "link": "http://foobar.com/category/foo/",
            "name": "Foo",
            "slug": "foo",
            "taxonomy": "category"
          },
          {
            "id": 8,
            "count": 9,
            "description": "",
            "link": "http://foobar.com/category/bar/",
            "name": "Bar",
            "slug": "bar",
            "taxonomy": "category"
          },
          {
            "id": 5,
            "count": 1,
            "description": "",
            "link": "http://foobar.com/category/mon/",
            "name": "Mon",
            "slug": "mon",
            "taxonomy": "category"
          },
          {
            "id": 11,
            "count": 8,
            "description": "",
            "link": "http://foobar.com/category/fort/",
            "name": "Fort",
            "slug": "fort",
            "taxonomy": "category"
          }
        ],
        "output": [
          "foo",
          "bar",
          "mon",
          "fort"
        ]
      }
    ],
    "identifier": 51335414
  },
  {
    "context": [
      "The problem I\u2019m trying to solve is to search for AWS SG group and add a new rule (eg: 10.10.0.0/16) to the same ingress rule block(port, protocal,cidr) where when the pattern is \u201cCidrIp\u201d: \u201c10.219.0.0/16\u201d matched.",
      "If your intention is to create a new `CidrIp` rule added when the value is `10.219.0.0/16`, do the following.",
      "jq 'if   .IpRanges[] | select(.CidrIp | contains(\"10.219.0.0/16\") ) then .IpRanges += [ { \"cidrIp\" : \"10.10.0.0/16\" } ] else . end' ingressJSON",
      "aws ec2 describe-security-groups --region ${i} |   \\\n  jq -r --arg e_cidr \"${existing_cidr}\" \\\n     --arg n_cidr \"${new_cidr}\" \\\n     '.SecurityGroups[] | .GroupId as $gid | .IpPermissions[] | .FromPort as $port | .IpProtocol as $protocol | \n     .IpRanges[] | select(.CidrIp == $e_cidr) | .Description as $desc |\n     [{ GroupId:$gid, IpProtocol:$protocol, FromPort:$port, ToPort:$port, IpRanges:[{CidrIp:$n_cidr, Description:$desc}] }] ' -c"
    ],
    "utterance": "Add '10.10.0.0/16' as a new ingress CidrIp to any rule where an existing IpRanges entry has CidrIp equal to '10.219.0.0/16'.",
    "expressions": [
      "if .IpRanges[] | select(.CidrIp | contains(\"10.219.0.0/16\")) then .IpRanges += [ { \"CidrIp\" : \"10.10.0.0/16\" } ] else . end",
      ".SecurityGroups[] | .GroupId as $gid | .IpPermissions[] | .FromPort as $port | .IpProtocol as $protocol | .IpRanges[] | select(.CidrIp == $e_cidr) | .Description as $desc | [{ GroupId:$gid, IpProtocol:$protocol, FromPort:$port, ToPort:$port, IpRanges:[{CidrIp:$n_cidr, Description:$desc}] }]"
    ],
    "data": [
      {
        "input": {
          "PrefixListIds": [],
          "FromPort": -1,
          "IpRanges": [
            {
              "CidrIp": "10.219.0.0/16"
            },
            {
              "Description": "testing for vpc transit connectivity",
              "CidrIp": "0.0.0.0/0"
            }
          ],
          "ToPort": -1,
          "IpProtocol": "icmp",
          "UserIdGroupPairs": [
            {
              "UserId": "abcde80269151",
              "Description": "default SG VPC\u200a-\u200apeering ",
              "GroupId": "sg-33511e41"
            }
          ],
          "Ipv6Ranges": []
        },
        "output": {
          "PrefixListIds": [],
          "FromPort": -1,
          "IpRanges": [
            {
              "CidrIp": "10.219.0.0/16"
            },
            {
              "CidrIp": "10.10.0.0/16"
            },
            {
              "Description": "testing for vpc transit connectivity",
              "CidrIp": "0.0.0.0/0"
            }
          ],
          "ToPort": -1,
          "IpProtocol": "icmp",
          "UserIdGroupPairs": [
            {
              "UserId": "abcde80269151",
              "Description": "default SG VPC - peering ",
              "GroupId": "sg-33511e41"
            }
          ],
          "Ipv6Ranges": []
        }
      }
    ],
    "identifier": 51294701
  },
  {
    "context": [
      "I am trying to get a list of key/value from a json and filter to keep unique value per keys that belong to a list/array.",
      "my keyList is \r\n\r\n    [\"key1\",\"key2\",\"key4\",\"key5\",\"key6\",\"key9\",\"key11\"]",
      "expected result is to retain only key/values that match with the keylist and to group the values by the keys.",
      "aggregate( tostream\n  | select(length==2 and (.[0][-1] | type == \"string\"))\n  | [.[0][-1], .[1]]\n  | select(.[0] as $k | $keyList|index($k) ))"
    ],
    "utterance": "Extract all unique values for keys listed in [\"key1\",\"key2\",\"key4\",\"key5\",\"key6\",\"key9\",\"key11\"] from the input object, grouping the results by key.",
    "expressions": [
      "aggregate( tostream\n  | select(length==2 and (.[0][-1] | type == \"string\"))\n  | [.[0][-1], .[1]]\n  | select(.[0] as $k | $keyList|index($k) ))"
    ],
    "data": [
      {
        "input": {
          "key0": {
            "key1": "valueA",
            "key2": 123456,
            "key3": [
              {
                "key4": "anotherValue41",
                "key5": "anotherValue51",
                "key6": 999
              },
              {
                "key4": "anotherValue42",
                "key5": "anotherValue52",
                "key6": 666
              }
            ],
            "key10": {
              "key11": "lastvalue"
            }
          }
        },
        "output": {
          "key1": [
            "valueA"
          ],
          "key2": [
            123456
          ],
          "key4": [
            "anotherValue41",
            "anotherValue42"
          ],
          "key5": [
            "anotherValue51",
            "anotherValue52"
          ],
          "key6": [
            999,
            666
          ],
          "key11": [
            "lastvalue"
          ]
        }
      }
    ],
    "identifier": 51370588
  },
  {
    "context": [
      "But adding a field to an existing object does not work as was expected, by displaying only the modified subtree:",
      "Desired output:",
      "{\r\n  \"e\": {\r\n    \"f\": \"g\",\r\n    \"h\": \"i\"\r\n  }\r\n}",
      "If your intention is just to append an element to an object, it would be better to use `+=` as",
      "jq '.e += { \"h\" : \"i\" }'",
      "echo '{ \"e\": { \"f\": \"g\" } }' | jq '.e += { \"h\" : \"i\" }'",
      "{\r\n  \"e\": {\r\n    \"f\": \"g\",\r\n    \"h\": \"i\"\r\n  }\r\n}"
    ],
    "utterance": "Add a field h with value i to the object under key e, so the result contains both f: g and h: i inside e.",
    "expressions": [
      ".e += { \"h\": \"i\" }"
    ],
    "data": [
      {
        "input": {
          "e": {
            "f": "g"
          }
        },
        "output": {
          "e": {
            "f": "g",
            "h": "i"
          }
        }
      }
    ],
    "identifier": 51379550
  },
  {
    "context": [
      "I am trying to update an environment variable value in my json. Can I do this by making use of a variable as reference?",
      "This works:",
      "map(if .name == \"ARTIFACT_LOCATION\" then . + {\"value\" : \"2\"} else . end)",
      "This does not: ... then . + {\"value\" : \"**$NEW_ARTIFACTORY_LOCATION**\"} ...",
      "If by `$**$NEW_ARTIFACTORY_LOCATION**` you intend to signify the value of the environment variable $NEW_ARTIFACTORY_LOCATION, then you could use `env.NEW_ARTIFACTORY_LOCATION`, e.g.",
      "map(if .name == \"ARTIFACT_LOCATION\" then . + {\"value\" : env.NEW_ARTIFACTORY_LOCATION} else . end)"
    ],
    "utterance": "Update the value field to the value of the shell variable NEW_ARTIFACTORY_LOCATION for objects whose name is ARTIFACT_LOCATION within environment arrays.",
    "expressions": [
      ".taskDefinition.containerDefinitions[].environment | map(if .name == \"ARTIFACT_LOCATION\" then . + {\"value\": env.NEW_ARTIFACTORY_LOCATION} else . end)"
    ],
    "identifier": 51388895
  },
  {
    "context": [
      "I have a JSON object that contains strings of JSON at various levels in the JSON such as the one below that I want converted to as nested JSON.",
      "I know it's possible to convert one specific object using `fromjson` but is there an easier way to convert all occurrances of these string to json?",
      "If your jq has `walk` then you can simply write:",
      "walk(if type==\"string\" then fromjson? // . else . end)",
      "Alternatively:",
      "def dej:\n  if type == \"string\" then fromjson? // . \n  elif type == \"object\" then map_values(dej)\n  elif type == \"array\" then map(dej)\n  else .\n  end;\ndej",
      "If you want `dej` as defined above to be applied as many times as required to achieve quiescence, then you could use this definition:",
      "def dejx:\n  def dej:\n    if type == \"string\" then fromjson? // . \n    elif type == \"object\" then map_values(dej)\n    elif type == \"array\" then map(dej)\n    else .\n    end;\n  dej as $d | if . == $d then . else $d|dejx end;",
      "For simple cases, you can just use `fromjson`, e.g. in your case:\n\n.scheme |= fromjson\n\t| .response.text |= fromjson"
    ],
    "utterance": "Recursively convert all string values that are valid JSON into their corresponding structures at every level of the input.",
    "expressions": [
      "walk(if type==\"string\" then fromjson? // . else . end)",
      "def dej:\n  if type == \"string\" then fromjson? // . \n  elif type == \"object\" then map_values(dej)\n  elif type == \"array\" then map(dej)\n  else .\n  end;\ndej",
      "def dejx:\n  def dej:\n    if type == \"string\" then fromjson? // . \n    elif type == \"object\" then map_values(dej)\n    elif type == \"array\" then map(dej)\n    else .\n    end;\n  dej as $d | if . == $d then . else $d|dejx end;\ndejx"
    ],
    "data": [
      {
        "input": {
          "requestType": "POST",
          "response": {
            "size": 2,
            "text": "{\"recordID\":1, \"title\":\"Hello\", \"content\":\"Lorem ipsum\"}"
          },
          "scheme": "{\"scheme\":\"https\"}"
        },
        "output": {
          "requestType": "POST",
          "response": {
            "size": 2,
            "text": {
              "recordID": 1,
              "title": "Hello",
              "content": "Lorem ipsum"
            }
          },
          "scheme": {
            "scheme": "https"
          }
        }
      }
    ],
    "identifier": 51354091
  },
  {
    "context": [
      "Now, i'm going to add `{city: tehran}` object to this array :",
      "./jq-linux64 --arg city tehran '.HotelInfo +{city: $city}' 74687.json ",
      "And it's done, but this doesn't reflect on file too and file still not updated with this new record, How can i update the json file as well?",
      "You need to write the results to a temporary file and rename that to the original one:",
      "./jq-linux64 --arg city tehran '.HotelInfo +{city: $city}' 74687.json > temp.json",
      "mv temp.json 74687.json",
      "If you want to keep your original json structure and just append the new value you could use:",
      "$ jq '.HotelInfo.city = \"tehran\"' 74687.json > 74687.jso.tmp",
      "$ mv 74687.json.tmp 74687.json",
      "This will update the file with all previous fields/objects if any:",
      "{ \"HotelInfo\": { \"HotelURL\": \"http://www.tripadvisor.com/aaa.html\", \"HotelID\": \"74687\", \"Price\": \"$156\", \"city\": \"tehran\" } }",
      "If you just want to create a new structure removing other possible keys within `.HotelInfo`",
      "$ jq --arg city tehran '.HotelInfo +{city: $city}' 74687.json > 74687.jso.tmp ",
      "$ mv 74687.json.tmp 74687.json",
      "This will create the file with the `Hotelinfo` object contents only:",
      "{ \"HotelURL\": \"http://www.tripadvisor.com/aaa.html\", \"HotelID\": \"74687\", \"Price\": \"$156\", \"city\": \"tehran\" }"
    ],
    "utterance": "Update a file by adding a city field with value \"tehran\" to the HotelInfo object, with an option to either preserve the original file structure or replace it with only the HotelInfo contents.",
    "expressions": [
      ".HotelInfo + {city: $city}",
      ".HotelInfo.city = \"tehran\""
    ],
    "data": [
      {
        "input": {
          "HotelInfo": {
            "HotelURL": "http://www.tripadvisor.com/aaa.html",
            "HotelID": "74687",
            "Price": "$156"
          }
        },
        "output": {
          "HotelInfo": {
            "HotelURL": "http://www.tripadvisor.com/aaa.html",
            "HotelID": "74687",
            "Price": "$156",
            "city": "tehran"
          }
        }
      },
      {
        "input": {
          "HotelInfo": {
            "HotelURL": "http://www.tripadvisor.com/aaa.html",
            "HotelID": "74687",
            "Price": "$156"
          }
        },
        "output": {
          "HotelURL": "http://www.tripadvisor.com/aaa.html",
          "HotelID": "74687",
          "Price": "$156",
          "city": "tehran"
        }
      }
    ],
    "identifier": 51363314
  },
  {
    "context": [
      "My goal is to make my original JSON completely valid both in (1) structure and  (2) with quotes in values escaped. I don't want any other quotes escaped than those inside the value -- for example:",
      "`\"c\": \"value with \\\"more\\\" than one set of \\\"quotes\\\"9\",`",
      "c is the only key whose value will ever have quotes within it.",
      "sed -E 's/\"/\\\\&/4g; s/\\\\\"(,)?$/\"\\1/' input.json | jq -s '.'",
      "The output:\n\n    [\n      {\n        \"a\": \"value1\",\n        \"b\": \"value with \\\"quotes\\\"2\",\n        \"c\": \"value with \\\"more\\\" than one set of \\\"quotes\\\"3\"\n      },\n      {\n        \"a\": \"value4\",\n        \"b\": \"value with \\\"quotes\\\"5\",\n        \"c\": \"value with \\\"more\\\" than one set of \\\"quotes\\\"6\"\n      },\n      {\n        \"a\": \"value7\",\n        \"b\": \"value with \\\"quotes\\\"8\",\n        \"c\": \"value with \\\"more\\\" than one set of \\\"quotes\\\"9\"\n      }\n    ]"
    ],
    "utterance": "Make values valid by escaping quotes inside the value for the key 'c', without escaping other quotes",
    "expressions": [
      "jq -s '.'"
    ],
    "data": [
      {
        "input": [
          {
            "a": "value1",
            "b": "value with \"quotes\"2",
            "c": "value with \"more\" than one set of \"quotes\"3"
          },
          {
            "a": "value4",
            "b": "value with \"quotes\"5",
            "c": "value with \"more\" than one set of \"quotes\"6"
          },
          {
            "a": "value7",
            "b": "value with \"quotes\"8",
            "c": "value with \"more\" than one set of \"quotes\"9"
          }
        ],
        "output": [
          {
            "a": "value1",
            "b": "value with \\\"quotes\\\"2",
            "c": "value with \\\"more\\\" than one set of \\\"quotes\\\"3"
          },
          {
            "a": "value4",
            "b": "value with \\\"quotes\\\"5",
            "c": "value with \\\"more\\\" than one set of \\\"quotes\\\"6"
          },
          {
            "a": "value7",
            "b": "value with \\\"quotes\\\"8",
            "c": "value with \\\"more\\\" than one set of \\\"quotes\\\"9"
          }
        ]
      }
    ],
    "identifier": 51390257
  },
  {
    "context": [
      "Input file has:",
      "{ \"a\" : \"test1\", \"b\" : 0}",
      "{ \"a\" : \"test2\", \"b\" : 0}",
      "{ \"a\" : \"test3\", \"b\" : 0}",
      "Desired output:",
      "{ \"a\" : \"test1\", \"b\" : 0}",
      "{ \"a\" : \"test2\", \"b\" : 1}",
      "{ \"a\" : \"test3\", \"b\" : 2}",
      "jq 1.5 has `inputs`, which opens the door to an efficient solution:",
      "jq -nc '\n  foreach inputs as $x (-1; .+1; \n    . as $n | $x | .[\"b\"] = $n)' stream.json\n{ \"a\":\"test1\",\"b\":0}\n{ \"a\":\"test2\",\"b\":1}\n{ \"a\":\"test3\",\"b\":2}"
    ],
    "utterance": "For each object in a newline-delimited file, set the field b to its zero-based line index.",
    "expressions": [
      "jq -nc 'foreach inputs as $x (-1; .+1; . as $n | $x | .[\"b\"] = $n)' stream.json"
    ],
    "data": [
      {
        "input": [
          {
            "a": "test1",
            "b": 0
          },
          {
            "a": "test2",
            "b": 0
          },
          {
            "a": "test3",
            "b": 0
          }
        ],
        "output": [
          {
            "a": "test1",
            "b": 0
          },
          {
            "a": "test2",
            "b": 1
          },
          {
            "a": "test3",
            "b": 2
          }
        ]
      }
    ],
    "identifier": 51409156
  },
  {
    "context": [
      "I think you just want to pass the key as an `--arg`:\n\n    jq --arg key \"solr.baseuri\" '.[$key]' file.json",
      "To extract the host to a variable, you could use `capture`:\n\n    $ value=$(jq --arg key solr.baseuri -r '.[$key] | capture(\".*://(?<host>[^:]+)\") | .host' file.json)\n    $ echo \"$value\"\n    10.201.17.8",
      "jq --arg key \"$key\" '\n  .[$key] | split(\"/\") | .[2] | split(\":\") | .[0]' test.json"
    ],
    "utterance": "Extract the IP address from the value of a property, where the property name is stored in a shell variable.",
    "expressions": [
      "jq --arg key \"$key\" -r '.[$key] | capture(\".*://(?<host>[^:]+)\") | .host' test.json",
      "jq --arg key \"$key\" '.[$key] | split(\"/\") | .[2] | split(\":\") | .[0]' test.json"
    ],
    "data": [
      {
        "input": {
          "solr.baseuri": "http://10.201.17.8:80"
        },
        "output": "10.201.17.8"
      }
    ],
    "identifier": 51422711
  },
  {
    "context": [
      "From here, what I want to achieve is that combining/concatenating fields so I can get the output like below:",
      "[\"A1\" \"B1, B2\" 10 \"E1\" \"F1\"]",
      "[\"A1\" \"B3, B4\" 20 \"E2\" \"F1\"]",
      "How do I use the right jq query to get the result I expected above?",
      "$ jq -c '.[] as $top | .[].B[] | [$top.A, (.B_array[] | join(\", \")), .C, .E, $top.F]' tmp.json",
      "[\"A1\",\"B1, B2\",10,\"E1\",\"F1\"]",
      "[\"A1\",\"B3, B4\",20,\"E2\",\"F1\"]"
    ],
    "utterance": "Extract, for each B element, a list containing the top-level A, the B_array fields joined by ', ', the C value, the E value, and the top-level F.",
    "expressions": [
      ".[] as $top | .B[] | [$top.A, (.B_array[] | join(\", \")), .C, .E, $top.F]"
    ],
    "data": [
      {
        "input": [
          {
            "A": "A1",
            "B": [
              {
                "B_array": [
                  {
                    "B_field1": "B1",
                    "B_field2": "B2"
                  }
                ],
                "C": 10,
                "E": "E1"
              },
              {
                "B_array": [
                  {
                    "B_field1": "B3",
                    "B_field2": "B4"
                  }
                ],
                "C": 20,
                "E": "E2"
              }
            ],
            "F": "F1"
          }
        ],
        "output": [
          [
            "A1",
            "B1, B2",
            10,
            "E1",
            "F1"
          ],
          [
            "A1",
            "B3, B4",
            20,
            "E2",
            "F1"
          ]
        ]
      }
    ],
    "identifier": 51427909
  },
  {
    "context": [
      "i m lie to use  bash to import data  from  cvs  to json  file",
      "And i want  some like this:\r\n\r\n    {\r\n    \"title\":\"Example\",\r\n    \"price\":200,\r\n    \"description\": {\r\n          \"plain_text\": \"Some here...\"\r\n       },\r\n    \"Predifined\":static content,\r\n    \"Another Predifined\":static content,\r\n    }",
      "After fixing your input so that it is properly semicolon-separated:\r\n\r\n    jq -R 'split(\";\")\r\n    | map(gsub(\"^\\\"|\\\"$\";\"\"))\r\n    | {title:.[1],\r\n       price: .[2],\r\n       description: { plain_text: .[3] }}' input.csv\r\n\r\nyields:\r\n\r\n    {\r\n      \"title\": \"Product Name\",\r\n      \"price\": \"Price\",\r\n      \"description\": {\r\n        \"plain_text\": \"Description\"\r\n      }\r\n    }\r\n    {\r\n      \"title\": \"Example\",\r\n      \"price\": \"200\",\r\n      \"description\": {\r\n        \"plain_text\": \"Descripcion here...\"\r\n      }\r\n    }\r\n    {\r\n      \"title\": \"Example2\",\r\n      \"price\": \"300\",\r\n      \"description\": {\r\n        \"plain_text\": \"Some here...\"\r\n      }\r\n    }"
    ],
    "utterance": "Convert CSV lines with semicolon-separated fields to objects with keys 'title', 'price', 'description.plain_text', adding 'Predifined' and 'Another Predifined' with static content",
    "expressions": [
      "jq -R 'split(\";\")\n| map(gsub(\"^\\\"|\\\"$\";\"\"))\n| {title:.[1],\n   price: .[2],\n   description: { plain_text: .[3] },\n   Predifined: \"static content\",\n   \"Another Predifined\": \"static content\"}' input.csv"
    ],
    "data": [
      {
        "input": "\"Product ID\";\"Product Name\";\"Price\";\"Description\";\n\"1;\"Example\";\"200\";\"Descripcion here...\";\n\"2;\"Example2\";\"300\";\"Some here...\";\n",
        "output": [
          {
            "title": "Product Name",
            "price": "Price",
            "description": {
              "plain_text": "Description"
            },
            "Predifined": "static content",
            "Another Predifined": "static content"
          },
          {
            "title": "Example",
            "price": "200",
            "description": {
              "plain_text": "Descripcion here..."
            },
            "Predifined": "static content",
            "Another Predifined": "static content"
          },
          {
            "title": "Example2",
            "price": "300",
            "description": {
              "plain_text": "Some here..."
            },
            "Predifined": "static content",
            "Another Predifined": "static content"
          }
        ]
      }
    ],
    "identifier": 51333916
  },
  {
    "context": [
      "I'm trying to extract \"W\"'s list.",
      "To extract just \"W\"'s list, you could use any of the following filters, depending on your precise requirements:",
      ".[] | select(has(\"W\")) | .W",
      ".[] | .W | select(.)",
      ".[] | .W // empty",
      ".[1].W",
      "Depending on the precise requirements, you can use any of the filters given above, for example:",
      "jq('.[] | .W // empty').transform(data)"
    ],
    "utterance": "Extract the array under the key \"W\" from an array of objects, where only one object contains the key.",
    "expressions": [
      ".[] | select(has(\"W\")) | .W",
      ".[] | .W | select(.)",
      ".[] | .W // empty",
      ".[1].W"
    ],
    "data": [
      {
        "input": [
          {
            "M": [
              {
                "id": 1,
                "nk": "MATH$$SPRING$$INST1$$2",
                "section": {
                  "nk": "MATH$$SPRING$$INST1",
                  "course": 1,
                  "id": 1
                },
                "location": {
                  "id": 1,
                  "nk": "mcu$$101",
                  "campus": {
                    "id": 1,
                    "nk": "mcu",
                    "name": "Main Campus"
                  },
                  "address": "1 st",
                  "building": "1",
                  "room": "101"
                },
                "day_of_week": 2,
                "start_time": "09:00:00",
                "end_time": "10:00:00"
              }
            ]
          },
          {
            "W": [
              {
                "id": 2,
                "nk": "MATH$$SPRING$$INST1$$4",
                "section": {
                  "nk": "MATH$$SPRING$$INST2",
                  "course": 1,
                  "id": 2
                },
                "location": {
                  "id": 2,
                  "nk": "mcu$$201",
                  "campus": {
                    "id": 1,
                    "nk": "mcu",
                    "name": "Main Campus"
                  },
                  "address": "1 st",
                  "building": "1",
                  "room": "201"
                },
                "day_of_week": 4,
                "start_time": "08:00:00",
                "end_time": "10:00:00"
              }
            ]
          }
        ],
        "output": [
          [
            {
              "id": 2,
              "nk": "MATH$$SPRING$$INST1$$4",
              "section": {
                "nk": "MATH$$SPRING$$INST2",
                "course": 1,
                "id": 2
              },
              "location": {
                "id": 2,
                "nk": "mcu$$201",
                "campus": {
                  "id": 1,
                  "nk": "mcu",
                  "name": "Main Campus"
                },
                "address": "1 st",
                "building": "1",
                "room": "201"
              },
              "day_of_week": 4,
              "start_time": "08:00:00",
              "end_time": "10:00:00"
            }
          ]
        ]
      }
    ],
    "identifier": 51432696
  },
  {
    "context": [
      "Each object MAY have `\"phenotypes\"`, which I need to modify the content of, as well as removing `\"note\"` from the top level object.",
      "My jq is as follows:\n\n    [ map(del(.note, .age)) | .[] | select(.phenotypes != null) | .phenotypes |= map(del(.person_id)) ]\n\n\nThis almost works, but because of `select(.phenotypes != null)`, the second object in the array never makes it back after filtering.",
      "My expected output is the following:\n\n    [\n      {\n        \"patient_id\": 1,\n        \"phenotypes\": [\n          {\n            \"name\": \"Breast carcinoma\",\n            \"observation\": \"present\",\n            \"patient_id\": 1\n          },\n          {\n            \"name\": \"Breast carcinoma\",\n            \"observation\": \"present\",\n            \"patient_id\": 1\n          }\n        ]\n      },\n      {\n        \"patient_id\": 2\n      },\n      {\n        \"patient_id\": 3,\n        \"phenotypes\": [\n          {\n            \"name\": \"Breast carcinoma\",\n            \"observation\": \"present\",\n            \"patient_id\": 3\n          },\n          {\n            \"name\": \"Breast carcinoma\",\n            \"observation\": \"present\",\n            \"patient_id\": 3\n          }\n        ]\n      }\n    ]",
      "This works for me:\n\n    map(del(.note, .age)) |\n    map( \n    \tif .phenotypes then \n          \t(.phenotypes |= map(del(.person_id)))\n    \telse\n    \t\t.\n    \tend \n    )"
    ],
    "utterance": "Remove the note field from each object in an array and, when present, remove person_id from each phenotypes object inside them, leaving other objects unchanged.",
    "expressions": [
      "map(del(.note, .age)) | map( if .phenotypes then (.phenotypes |= map(del(.person_id))) else . end )"
    ],
    "data": [
      {
        "input": [
          {
            "note": null,
            "patient_id": 1,
            "phenotypes": [
              {
                "name": "Breast carcinoma",
                "observation": "present",
                "patient_id": 1,
                "person_id": 1
              },
              {
                "name": "Breast carcinoma",
                "observation": "present",
                "patient_id": 1,
                "person_id": 1
              }
            ]
          },
          {
            "note": null,
            "patient_id": 2
          },
          {
            "note": null,
            "patient_id": 3,
            "phenotypes": [
              {
                "name": "Breast carcinoma",
                "observation": "present",
                "patient_id": 3,
                "person_id": 3
              },
              {
                "name": "Breast carcinoma",
                "observation": "present",
                "patient_id": 3,
                "person_id": 3
              }
            ]
          }
        ],
        "output": [
          {
            "patient_id": 1,
            "phenotypes": [
              {
                "name": "Breast carcinoma",
                "observation": "present",
                "patient_id": 1
              },
              {
                "name": "Breast carcinoma",
                "observation": "present",
                "patient_id": 1
              }
            ]
          },
          {
            "patient_id": 2
          },
          {
            "patient_id": 3,
            "phenotypes": [
              {
                "name": "Breast carcinoma",
                "observation": "present",
                "patient_id": 3
              },
              {
                "name": "Breast carcinoma",
                "observation": "present",
                "patient_id": 3
              }
            ]
          }
        ]
      }
    ],
    "identifier": 51440863
  },
  {
    "context": [
      "My question is: can I replace comma in the field using jq-win ?",
      "For example, use `gsub`, pretty much as you\u2019d use awk\u2019s `gsub`, e.g.",
      "gsub(\",\"; \"|\")",
      ".[] | .name |= gsub(\",\";\";\") | [.[]] | map(tostring) | join(\",\")",
      "1083,AAAAA,8,",
      "1084,bbbbb,7,",
      "1088,CCCCCC,131,",
      "1089,DDD;DDD,132,"
    ],
    "utterance": "Replace commas with semicolons in the value of the 'name' field for each record",
    "expressions": [
      ".[] | .name |= gsub(\",\";\";\")"
    ],
    "data": [
      {
        "input": [
          {
            "id": "1083",
            "name": "AAAAA",
            "channelNumber": 8,
            "channelImage": ""
          },
          {
            "id": "1084",
            "name": "bbbbb",
            "channelNumber": 7,
            "channelImage": ""
          },
          {
            "id": "1088",
            "name": "CCCCCC",
            "channelNumber": 131,
            "channelImage": ""
          },
          {
            "id": "1089",
            "name": "DDD,DDD",
            "channelNumber": 132,
            "channelImage": ""
          }
        ],
        "output": [
          {
            "id": "1083",
            "name": "AAAAA",
            "channelNumber": 8,
            "channelImage": ""
          },
          {
            "id": "1084",
            "name": "bbbbb",
            "channelNumber": 7,
            "channelImage": ""
          },
          {
            "id": "1088",
            "name": "CCCCCC",
            "channelNumber": 131,
            "channelImage": ""
          },
          {
            "id": "1089",
            "name": "DDD;DDD",
            "channelNumber": 132,
            "channelImage": ""
          }
        ]
      }
    ],
    "identifier": 51441986
  },
  {
    "context": [
      "Suppose my input was this: `[1,2,3,4,5,6,7,8,9,10]`, and I wanted to split it into 3 element long chunks. The desired output from `jq` would be:\n\n    [1,2,3]\n    [4,5,6]\n    [7,8,9]\n    [10]",
      "here's a simple one that worked for me:\n```jq\ndef chunk(n):\n    range(length/n|ceil) as $i | .[n*$i:n*$i+n];\n```",
      "example usage:\n```shell\njq -n \\\n'def chunk(n): range(length/n|ceil) as $i | .[n*$i:n*$i+n];\n[range(5)] | chunk(2)'\n[\n  0,\n  1\n]\n[\n  2,\n  3\n]\n[\n  4\n]\n```",
      "There is an (undocumented) builtin, `_nwise`, that meets the functional requirements:\n\n    $ jq -nc '[1,2,3,4,5,6,7,8,9,10] | _nwise(3)'\n\n    [1,2,3]\n    [4,5,6]\n    [7,8,9]\n    [10]",
      "def nwise($n):\n def _nwise:\n   if length <= $n then . else .[0:$n] , (.[$n:]|_nwise) end;\n _nwise;"
    ],
    "utterance": "Split the array [1,2,3,4,5,6,7,8,9,10] into subarrays of size 3, with the last chunk containing any remaining elements.",
    "expressions": [
      "def chunk(n): range(length/n|ceil) as $i | .[n*$i:n*$i+n]; . | chunk(3)",
      "_nwise(3)",
      "def nwise($n): def _nwise: if length <= $n then . else .[0:$n] , (.[$n:]|_nwise) end; _nwise; . | nwise(3)"
    ],
    "data": [
      {
        "input": [
          1,
          2,
          3,
          4,
          5,
          6,
          7,
          8,
          9,
          10
        ],
        "output": [
          [
            1,
            2,
            3
          ],
          [
            4,
            5,
            6
          ],
          [
            7,
            8,
            9
          ],
          [
            10
          ]
        ]
      }
    ],
    "identifier": 51412721
  },
  {
    "context": [
      "I have a json file and I want to add some value from top in another place in json.",
      "in my json the \"channel\" is static, same value always. I need a way to concatenate always in each video array.",
      "Use a variable to remember `.channel` in the later stages of the pipeline.",
      "$ jq '.channel as $ch | .videos[].channel = $ch' tmp.json"
    ],
    "utterance": "For each object in the videos array, add a field named channel with the value from the top-level channel field.",
    "expressions": [
      ".channel as $ch | .videos |= map(. + {channel: $ch})"
    ],
    "data": [
      {
        "input": {
          "channel": "mychannel",
          "videos": [
            {
              "id": "10",
              "url": "youtube.com"
            },
            {
              "id": "20",
              "url": "youtube.com"
            }
          ]
        },
        "output": {
          "channel": "mychannel",
          "videos": [
            {
              "id": "10",
              "url": "youtube.com",
              "channel": "mychannel"
            },
            {
              "id": "20",
              "url": "youtube.com",
              "channel": "mychannel"
            }
          ]
        }
      }
    ],
    "identifier": 51449999
  },
  {
    "context": [
      "I would like to add the element {\"test\" : \"2\"}in propDefs[] if the .children[].type==\"environmentApprovalTask\" and .children[].role.name== \"GCM approver\" and output that to the new file. I want the entire file with the modified content.",
      "TIL about complex assignments in `jq`. This actually works:",
      "(.children[] | select(.type==\"envApprovalTask\" and .role.name==\"Approver\") | .propDefs) |= .+[{\"test\":\"2\"}]"
    ],
    "utterance": "Add {\"test\": \"2\"} to the propDefs array for every child where type is \"envApprovalTask\" and role.name is \"Approver\", and print the entire modified structure.",
    "expressions": [
      "(.children[] | select(.type==\"envApprovalTask\" and .role.name==\"Approver\") | .propDefs) |= .+[{\"test\":\"2\"}]"
    ],
    "data": [
      {
        "input": {
          "edges": [
            {
              "to": "de32e562319310b7b4fe3736e22009",
              "from": "99d5f0b278f08721adba7741b782d8",
              "type": "SUCCESS",
              "value": ""
            },
            {
              "to": "06916609ad7fd4127815be3f075c81",
              "from": "de32e562319310b7b4fe3736e22009",
              "type": "SUCCESS",
              "value": ""
            },
            {
              "to": "99d5f0b278f08721adba7741b782d8",
              "type": "ALWAYS",
              "value": ""
            }
          ],
          "offsets": [
            {
              "name": "99d5f0b278f08721adba7741b782d8",
              "x": -91,
              "y": 100,
              "h": 70,
              "w": 290
            },
            {
              "name": "06916609ad7fd4127815be3f075c81",
              "x": -5,
              "y": 420,
              "h": 80,
              "w": 120
            },
            {
              "name": "de32e562319310b7b4fe3736e22009",
              "x": 69,
              "y": 240,
              "h": 70,
              "w": 240
            }
          ],
          "layoutMode": "manual",
          "type": "graph",
          "id": "d5d9c4c4-0c5f-4642-872c-ac892039eaa4",
          "name": "79e8b952-dd59-4cfd-9c0c-e6c08a81d4ca",
          "children": [
            {
              "type": "finish",
              "id": "833e959c-6825-413d-afc4-7b74c0a87c3e",
              "name": "06916609ad7fd4127815be3f075c81",
              "children": []
            },
            {
              "id": "e976041d-af9d-48cf-b838-735bb5efd483",
              "type": "envApprovalTask",
              "children": [],
              "name": "de32e562319310b7b4fe3736e22009",
              "roleRestrictionData": {
                "contextType": "ENVIRONMENT",
                "roleRestrictions": [
                  {
                    "roleId": "087175fb-5d38-42d1-b65a-2b6a6958bc21"
                  }
                ]
              },
              "propDefs": [
                {
                  "test": "1"
                }
              ],
              "templateName": "ApprovalCreated",
              "commentRequired": false,
              "commentPrompt": "",
              "role": {
                "id": "087175fb-5d38-42d1-b65a-2b6a6958bc21",
                "name": "Approver",
                "isDeletable": true
              }
            },
            {
              "id": "513fbc6a-3c4a-4a10-9eb0-7dc893c69413",
              "type": "environmentApprovalTask",
              "children": [],
              "name": "99d5f0b278f08721adba7741b782d8",
              "roleRestrictionData": {
                "contextType": "ENVIRONMENT",
                "roleRestrictions": [
                  {
                    "roleId": "116b8cd5-e7e4-403d-9599-35fe25d3cba2"
                  }
                ]
              },
              "propDefs": [],
              "templateName": "ApprovalCreated",
              "commentRequired": false,
              "commentPrompt": "",
              "role": {
                "id": "116b8cd5-e7e4-403d-9599-35fe25d3cba2",
                "name": "Manager Approver",
                "isDeletable": true
              }
            }
          ]
        }
      }
    ],
    "identifier": 51441674
  },
  {
    "context": [
      "Given two json files like this:\r\n\r\n    {\r\n      \"items\": [\r\n        {\r\n          \"name\": \"Item 1\"\r\n        },\r\n        {\r\n          \"name\": \"Item 2\"\r\n        },\r\n        {\r\n          \"name\": \"Item 3\"\r\n        }\r\n      ]\r\n    }\r\n\r\nand this:\r\n\r\n    [\r\n      \"Item 1 translated\",\r\n      \"Item 2 translated\",\r\n      \"Item 3 translated\"\r\n    ]\r\n\r\n\u2014 is it possible to apply the latter as a patch for the former? So that the final result would look like:\r\n\r\n    {\r\n      \"items\": [\r\n        {\r\n          \"name\": \"Item 1 translated\"\r\n        },\r\n        {\r\n          \"name\": \"Item 2 translated\"\r\n        },\r\n        {\r\n          \"name\": \"Item 3 translated\"\r\n        }\r\n      ]\r\n    }",
      "$ jq -s -f patch.jq object.json array.json",
      "where patch.jq contains:\r\n\r\n    .[1] as $array\r\n    | .[0]\r\n    | .items |= reduce range(0;length) as $i (.; \r\n                  .[$i].name = $array[$i])"
    ],
    "utterance": "Replace the values of the 'name' keys in each item of the 'items' array with the corresponding strings from a separate array of translated names.",
    "expressions": [
      ".[1] as $array | .[0] | .items |= reduce range(0;length) as $i (. ; .[$i].name = $array[$i])"
    ],
    "data": [
      {
        "input": [
          {
            "items": [
              {
                "name": "Item 1"
              },
              {
                "name": "Item 2"
              },
              {
                "name": "Item 3"
              }
            ]
          },
          [
            "Item 1 translated",
            "Item 2 translated",
            "Item 3 translated"
          ]
        ],
        "output": {
          "items": [
            {
              "name": "Item 1 translated"
            },
            {
              "name": "Item 2 translated"
            },
            {
              "name": "Item 3 translated"
            }
          ]
        }
      }
    ],
    "identifier": 51445949
  },
  {
    "context": [
      "To import to an OLAP system with limited feature set,  I need to have the order explicitly stated. So I need to add a `sn` for each change in a transaction.",
      "Also, each change must be a top level entry - the OLAP can't iterate sub-items within one entry.",
      "The following helper function converts the incoming array into an object using `headers` as the keys:",
      "def objectify(headers):\n  [headers, .] | transpose | map({(.[0]): .[1]}) | add;",
      "The trick now is to use `range(0;length)` to generate `.sn`:",
      "{xid} +\n  (.change\n   | range(0;length) as $i\n   | .[$i]\n   | .columnnames as $header\n   | {sn: ($i + 1),\n      kind,\n      data: (.columnvalues|objectify($header)) } )",
      "For the given log entry, the output would be:\n\n{\"xid\":1190,\"sn\":1,\"kind\":\"update\",\"data\":{\"id\":401,\"name\":\"Update AA\",\"age\":20}}\n{\"xid\":1190,\"sn\":2,\"kind\":\"update\",\"data\":{\"id\":401,\"name\":\"Update BB\",\"age\":20}}"
    ],
    "utterance": "Flatten each transaction by outputting one entry per change, adding an sn field for its order, and mapping columnnames/columnvalues to the data object.",
    "expressions": [
      "def objectify(headers): [headers, .] | transpose | map({(.[0]): .[1]}) | add;\n\n{xid} +\n  (.change\n   | range(0;length) as $i\n   | .[$i]\n   | .columnnames as $header\n   | {sn: ($i + 1),\n      kind,\n      data: (.columnvalues|objectify($header)) } )"
    ],
    "data": [
      {
        "input": {
          "xid": 1190,
          "timestamp": "2018-07-19 17:18:02.905354+02",
          "change": [
            {
              "kind": "update",
              "table": "mytable2",
              "columnnames": [
                "id",
                "name",
                "age"
              ],
              "columnvalues": [
                401,
                "Update AA",
                20
              ],
              "oldkeys": {
                "keynames": [
                  "id"
                ],
                "keyvalues": [
                  401
                ]
              }
            },
            {
              "kind": "update",
              "table": "mytable2",
              "columnnames": [
                "id",
                "name",
                "age"
              ],
              "columnvalues": [
                401,
                "Update BB",
                20
              ],
              "oldkeys": {
                "keynames": [
                  "id"
                ],
                "keyvalues": [
                  401
                ]
              }
            }
          ]
        },
        "output": [
          {
            "xid": 1190,
            "sn": 1,
            "kind": "update",
            "data": {
              "id": 401,
              "name": "Update AA",
              "age": 20
            }
          },
          {
            "xid": 1190,
            "sn": 2,
            "kind": "update",
            "data": {
              "id": 401,
              "name": "Update BB",
              "age": 20
            }
          }
        ]
      }
    ],
    "identifier": 51427332
  },
  {
    "context": [
      "Required is to take from `\"type\": \"openstack_compute_floatingip_v2\"` replace `.primary.attributes.address` and `.fixed_ip` and from corresponding `.instance_id` the `.name`.",
      "So, sth like:\n\n    {\"address\": \"209.66.89.143\",\n    \"fixed_ip\": \"10.10.10.5\",\n    \"name\": \"ctl01\"}",
      "Let\u2019s assume the two related objects are in a file named two.json.  Then one way to merge the information from both objects is using the `-s` command-line option, e.g.\n\n    jq -s '(\n      .[0].primary.attributes | {address, fixed_ip})\n      + {name: .[1].primary.attributes.name}' two.json",
      "With your example input, the output would be:\n\n    {\n      \"address\": \"209.66.89.143\",\n      \"fixed_ip\": \"10.10.10.5\",\n      \"name\": \"ctl01\"\n    }"
    ],
    "utterance": "Extract the address and fixed_ip from an openstack floating IP resource and the name from the corresponding instance with matching instance_id.",
    "expressions": [
      "jq -s '([.[].primary.attributes] | {address: .[0].address, fixed_ip: .[0].fixed_ip, name: .[1].name})' two.json",
      "jq -s ' (.[0].primary.attributes | {address, fixed_ip}) + {name: .[1].primary.attributes.name}' two.json"
    ],
    "data": [
      {
        "input": [
          {
            "type": "openstack_compute_floatingip_v2",
            "depends_on": [
              "openstack_networking_router_interface_v2.management"
            ],
            "primary": {
              "id": "48b039fc-a9fa-4672-934a-32d6d267f280",
              "attributes": {
                "address": "209.66.89.143",
                "fixed_ip": "10.10.10.5",
                "id": "48b039fc-a9fa-4672-934a-32d6d267f280",
                "instance_id": "597e75e8-834d-4f05-8408-e2e6e733577e",
                "pool": "public",
                "region": "RegionOne"
              },
              "meta": {},
              "tainted": false
            },
            "deposed": [],
            "provider": "provider.openstack"
          },
          {
            "type": "openstack_compute_instance_v2",
            "depends_on": [
              "openstack_compute_floatingip_v2.management",
              "openstack_compute_secgroup_v2.ssh_only",
              "openstack_networking_network_v2.management"
            ],
            "primary": {
              "id": "597e75e8-834d-4f05-8408-e2e6e733577e",
              "attributes": {
                "access_ip_v4": "10.10.10.5",
                "access_ip_v6": "",
                "name": "ctl01"
              },
              "meta": {},
              "tainted": false
            },
            "deposed": [],
            "provider": "provider.openstack"
          }
        ],
        "output": {
          "address": "209.66.89.143",
          "fixed_ip": "10.10.10.5",
          "name": "ctl01"
        }
      }
    ],
    "identifier": 51417144
  },
  {
    "context": [
      "I want to extract the value for `server` and the value of `for_user` any occurence where user2 is found as a name in `.keys[]`.",
      "the output could look like this:\r\n\r\n    example1, git\r\n    example2, root\r\n    example2, www",
      "How could I also print a value in the selected array element?",
      "You can use the following `jq` command:\r\n\r\n    jq -r '.[]|\"\\(.server), \\(.keys[]|select(.name==\"user2\").for_user)\"'"
    ],
    "utterance": "List the server and for_user values for all entries where a key has name equal to user2.",
    "expressions": [
      ".[] | \"\u0001(.server), \u0001(.keys[] | select(.name==\"user2\").for_user)\""
    ],
    "data": [
      {
        "input": [
          {
            "server": "example_1",
            "version": "Debian8",
            "keys": [
              {
                "fingerprint": "SHA256:fingerprint1",
                "for_user": "root",
                "name": "user1"
              },
              {
                "fingerprint": "SHA256:fingerprint2",
                "for_user": "git",
                "name": "user2"
              }
            ]
          },
          {
            "server": "example_2",
            "version": "Debian9",
            "keys": [
              {
                "fingerprint": "SHA256:fingerprint2",
                "for_user": "root",
                "name": "user2"
              },
              {
                "fingerprint": "SHA256:fingerprint2",
                "for_user": "www",
                "name": "user2"
              }
            ]
          },
          {
            "server": "example_3",
            "version": "CentOS",
            "keys": [
              null
            ]
          }
        ],
        "output": [
          "example_1, git",
          "example_2, root",
          "example_2, www"
        ]
      }
    ],
    "identifier": 51476598
  },
  {
    "context": [
      "jq \"$addJson + .\" > \"$dir/$layerId/json\" <<-'EOJSON'",
      "jq --raw-output \"$imageOldConfig + del(.history, .rootfs)\" \"$dir/$configFile\" > \"$dir/$imageId/json\"",
      "jq --raw-output --argjson imageOldConfig \"$imageOldConfig\" '\n    $imageOldConfig + del(.history, .rootfs)'",
      "cat \"$dir/$configFile\" | jq --raw-output \"$imageOldConfig + del(.history, .rootfs)\" > \"$dir/$imageId/json\""
    ],
    "utterance": "Combine an object with keys id and parent with another object by merging their properties, or merge a variable object with JSON read from a file, deleting keys history and rootfs.",
    "expressions": [
      "jq '$addJson + .' configFile",
      "jq --raw-output \"$imageOldConfig + del(.history, .rootfs)\" \"$dir/$configFile\"",
      "jq --raw-output --argjson imageOldConfig \"$imageOldConfig\" '$imageOldConfig + del(.history, .rootfs)'",
      "cat \"$dir/$configFile\" | jq --raw-output \"$imageOldConfig + del(.history, .rootfs)\""
    ],
    "data": [
      {
        "input": {
          "architecture": "amd64",
          "config": {
            "Hostname": "",
            "Domainname": "",
            "User": "",
            "AttachStdin": false,
            "AttachStdout": false,
            "AttachStderr": false,
            "Tty": false,
            "OpenStdin": false,
            "StdinOnce": false,
            "Env": [
              "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"
            ],
            "Cmd": [
              "/bin/bash"
            ],
            "ArgsEscaped": true,
            "Image": "sha256:c2775c69594daa3ee360d8e7bbca93c65d9c925e89bd731f12515f9bf8382164",
            "Volumes": null,
            "WorkingDir": "",
            "Entrypoint": null,
            "OnBuild": null,
            "Labels": null
          },
          "container": "6713e927cc43b61a4ce3950a69907336ff55047bae9393256e32613a54321c70",
          "container_config": {
            "Hostname": "6713e927cc43",
            "Domainname": "",
            "User": "",
            "AttachStdin": false,
            "AttachStdout": false,
            "AttachStderr": false,
            "Tty": false,
            "OpenStdin": false,
            "StdinOnce": false,
            "Env": [
              "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"
            ],
            "Cmd": [
              "/bin/sh",
              "-c",
              "#(nop) ",
              "CMD [\"/bin/bash\"]"
            ],
            "ArgsEscaped": true,
            "Image": "sha256:c2775c69594daa3ee360d8e7bbca93c65d9c925e89bd731f12515f9bf8382164",
            "Volumes": null,
            "WorkingDir": "",
            "Entrypoint": null,
            "OnBuild": null,
            "Labels": {}
          },
          "created": "2018-06-05T21:20:54.310450149Z",
          "docker_version": "17.06.2-ce",
          "history": [
            {
              "created": "2018-06-05T21:20:51.286433694Z",
              "created_by": "/bin/sh -c #(nop) ADD file:28c0771e44ff530dba3f237024acc38e8ec9293d60f0e44c8c78536c12f13a0b in / "
            },
            {
              "created": "2018-06-05T21:20:52.045074543Z",
              "created_by": "/bin/sh -c set -xe \t\t&& echo '#!/bin/sh' > /usr/sbin/policy-rc.d \t&& echo 'exit 101' >> /usr/sbin/policy-rc.d \t&& chmod +x /usr/sbin/policy-rc.d \t\t&& dpkg-divert --local --rename --add /sbin/initctl \t&& cp -a /usr/sbin/policy-rc.d /sbin/initctl \t&& sed -i 's/^exit.*/exit 0/' /sbin/initctl \t\t&& echo 'force-unsafe-io' > /etc/dpkg/dpkg.cfg.d/docker-apt-speedup \t\t&& echo 'DPkg::Post-Invoke { \"rm -f /var/cache/apt/archives/*.deb /var/cache/apt/archives/partial/*.deb /var/cache/apt/*.bin || true\"; };' > /etc/apt/apt.conf.d/docker-clean \t&& echo 'APT::Update::Post-Invoke { \"rm -f /var/cache/apt/archives/*.deb /var/cache/apt/archives/partial/*.deb /var/cache/apt/*.bin || true\"; }' >> /etc/apt/apt.conf.d/docker-clean \t&& echo 'Dir::Cache::pkgcache \"\"; Dir::Cache::srcpkgcache \"\";' >> /etc/apt/apt.conf.d/docker-clean \t\t&& echo 'Acquire::Languages \"none\";' > /etc/apt/apt.conf.d/docker-no-languages \t\t&& echo 'Acquire::GzipIndexes \"true\"; Acquire::CompressionTypes::Order:: \"gz\";' > /etc/apt/apt.conf.d/docker-gzip-indexes \t\t&& echo 'Apt::AutoRemove::SuggestsImportant \"false\";' > /etc/apt/apt.conf.d/docker-autoremove-suggests"
            },
            {
              "created": "2018-06-05T21:20:52.712120056Z",
              "created_by": "/bin/sh -c rm -rf /var/lib/apt/lists/*"
            },
            {
              "created": "2018-06-05T21:20:53.405342638Z",
              "created_by": "/bin/sh -c sed -i 's/^#\\s*\\(deb.*universe\\)$/\\1/g' /etc/apt/sources.list"
            },
            {
              "created": "2018-06-05T21:20:54.091704323Z",
              "created_by": "/bin/sh -c mkdir -p /run/systemd && echo 'docker' > /run/systemd/container"
            },
            {
              "created": "2018-06-05T21:20:54.310450149Z",
              "created_by": "/bin/sh -c #(nop)  CMD [\"/bin/bash\"]",
              "empty_layer": true
            }
          ],
          "os": "linux",
          "rootfs": {
            "type": "layers",
            "diff_ids": [
              "sha256:db9476e6d963ed2b6042abef1c354223148cdcdbd6c7416c71a019ebcaea0edb",
              "sha256:3a89e0d8654e098e949764b1cb23018e27f299b0931c5fd41c207d610ff356c4",
              "sha256:904d60939c360b5f528b886c1b534855a008f9a7fd411d4977e09aa7de74c834",
              "sha256:a20a262b87bd8a00717f3b30c001bcdaf0fd85d049e6d10500597caa29c013c5",
              "sha256:b6f13d447e00fba3b9bd10c1e5c6697e913462f44aa24af349bfaea2054e32f4"
            ]
          }
        },
        "output": {
          "architecture": "amd64",
          "config": {
            "Hostname": "",
            "Domainname": "",
            "User": "",
            "AttachStdin": false,
            "AttachStdout": false,
            "AttachStderr": false,
            "Tty": false,
            "OpenStdin": false,
            "StdinOnce": false,
            "Env": [
              "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"
            ],
            "Cmd": [
              "/bin/bash"
            ],
            "ArgsEscaped": true,
            "Image": "sha256:c2775c69594daa3ee360d8e7bbca93c65d9c925e89bd731f12515f9bf8382164",
            "Volumes": null,
            "WorkingDir": "",
            "Entrypoint": null,
            "OnBuild": null,
            "Labels": null
          },
          "container": "6713e927cc43b61a4ce3950a69907336ff55047bae9393256e32613a54321c70",
          "container_config": {
            "Hostname": "6713e927cc43",
            "Domainname": "",
            "User": "",
            "AttachStdin": false,
            "AttachStdout": false,
            "AttachStderr": false,
            "Tty": false,
            "OpenStdin": false,
            "StdinOnce": false,
            "Env": [
              "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"
            ],
            "Cmd": [
              "/bin/sh",
              "-c",
              "#(nop) ",
              "CMD [\"/bin/bash\"]"
            ],
            "ArgsEscaped": true,
            "Image": "sha256:c2775c69594daa3ee360d8e7bbca93c65d9c925e89bd731f12515f9bf8382164",
            "Volumes": null,
            "WorkingDir": "",
            "Entrypoint": null,
            "OnBuild": null,
            "Labels": {}
          },
          "created": "2018-06-05T21:20:54.310450149Z",
          "docker_version": "17.06.2-ce",
          "os": "linux"
        }
      }
    ],
    "identifier": 50992645
  },
  {
    "context": [
      "And I'm trying to get value for field `@def-ghi`.",
      "jq '.abc.@def-ghi'",
      "jq: error: syntax error, unexpected '-', expecting QQSTRING_START (Unix shell quoting issues?) at <top-level>, line 1:",
      "You need to quote the key:",
      "$ echo '...' | jq '.abc.\"@def-ghi\"'",
      "\"value1\"",
      "jq '.abc|.[\"@def-ghi\"]'"
    ],
    "utterance": "Retrieve the value associated with the field named '@def-ghi' inside the object 'abc', where the field name contains special characters.",
    "expressions": [
      ".abc[\"@def-ghi\"]",
      ".abc.\"@def-ghi\""
    ],
    "data": [
      {
        "input": {
          "abc": {
            "@def-ghi": "value1",
            "xyz": "value2"
          }
        },
        "output": "value1"
      }
    ],
    "identifier": 51494389
  },
  {
    "context": [
      "I want to flatten the inner array - `.site.alerts.instances` to get the following JSON:",
      "fields from the parent object, which are not part of the array (e.g. `.site.@name`) are not included.",
      "just use that logic to re-construct the JSON as you need as",
      "jq '{ \"@name\" : .site.\"@name\", \n      \"@ssl\"  : .site.\"@ssl\", \n      \"alerts\": [.site.alerts[] as $in | $in.instances[] as $h | $in | del(.instances) as $in2 | $h * $in2 ]}' json"
    ],
    "utterance": "Flatten each alert's instances, merging them with alert metadata, and include the parent '@name' and '@ssl' fields at the top level.",
    "expressions": [
      "{ \"@name\" : .site.\"@name\", \"@ssl\" : .site.\"@ssl\", \"alerts\": [ .site.alerts[] as $in | $in.instances[] as $h | $in | del(.instances) as $in2 | $h * $in2 ] }"
    ],
    "data": [
      {
        "input": {
          "@version": "2.7.0",
          "site": {
            "@name": "http://api:9999",
            "@ssl": "false",
            "alerts": [
              {
                "pluginid": "10094",
                "desc": "<p>Base64 encoded data was disclosed by the application/web server</p>",
                "instances": [
                  {
                    "uri": "http://api:9999",
                    "method": "POST",
                    "evidence": "DxyPP_YQ6qdWA_Kw_ZLgYilIkXCz93Xs1CeJPvg"
                  },
                  {
                    "uri": "http://api:9999",
                    "method": "POST",
                    "evidence": "eyJuYmYiOjE121lMWF1siSG9tZUFwcCJdfQ"
                  }
                ],
                "count": "37"
              }
            ]
          }
        },
        "output": {
          "@name": "http://api:9999",
          "@ssl": "false",
          "alerts": [
            {
              "pluginid": "10094",
              "desc": "<p>Base64 encoded data was disclosed by the application/web server</p>",
              "uri": "http://api:9999",
              "method": "POST",
              "evidence": "DxyPP_YQ6qdWA_Kw_ZLgYilIkXCz93Xs1CeJPvg",
              "count": "37"
            },
            {
              "pluginid": "10094",
              "desc": "<p>Base64 encoded data was disclosed by the application/web server</p>",
              "uri": "http://api:9999",
              "method": "POST",
              "evidence": "eyJuYmYiOjE121lMWF1siSG9tZUFwcCJdfQ",
              "count": "37"
            }
          ]
        }
      }
    ],
    "identifier": 51477085
  },
  {
    "context": [
      "eval \"$(jq -r '.params[] | \"export \\(.Name | @sh)=\\(.Value | @sh)\"' <<<\"$json\")\"",
      "The `@sh` builtin in `jq` escapes content to be `eval`-safe in bash, and the `eval` invocation then ensures that the content goes through all parsing stages (so literal quotes in the data emitted by `jq` become syntactic).",
      "jq -j '.params[] | ((.Name | gsub(\"\\u0000\"; \"\")), \"\\u0000\", (.Value | gsub(\"\\u0000\"; \"\")), \"\\u0000\")'",
      "mapfile -t KEY < <( jq -r '.params[] | .Value' <<< \"$json\" )",
      "mapfile -d $'\\0' KEY < <( jq -r -j '.params[] | .Value + \"\\u0000\"' <<< \"$json\" )"
    ],
    "utterance": "Export environment variables with values that may contain spaces, based on key-value pairs in the input where the key is in the 'Name' field and the value in the 'Value' field.",
    "expressions": [
      ".params[] | \"export \\(.Name | @sh)=\\(.Value | @sh)\"",
      ".params[] | ((.Name | gsub(\"\\u0000\"; \"\")), \"\\u0000\", (.Value | gsub(\"\\u0000\"; \"\")), \"\\u0000\")",
      ".params[] | .Value",
      ".params[] | .Value + \"\\u0000\""
    ],
    "data": [
      {
        "input": {
          "params": [
            {
              "Name": "KEY",
              "Value": "value with space"
            }
          ]
        },
        "output": [
          "export KEY='value with space'"
        ]
      }
    ],
    "identifier": 51482065
  },
  {
    "context": [
      "echo '{ \"a\": { \"b\":\"c\", \"d\":\"e\" } }{ \"a\": { \"b\":\"f\", \"d\":\"g\" } }' | jq '.'",
      "desired output:\n\n    {\n       \"c\": \"e\",\n       \"f\": \"g\"\n    }\n\nor (suits better for follow up usage):\n\n    {\n       x: {\n          \"c\": \"e\",\n          \"f\": \"g\"\n       }\n    }",
      "echo '{ \"a\": { \"b\": \"c\", \"d\": \"e\" } }{ \"a\": { \"b\": \"f\", \"d\": \"g\" } }' | jq -n '{ x: [inputs | .a | { (.b): .d} ] | add }'",
      "[inputs | .a | { (.b): .d} ] | add",
      "{x: _}"
    ],
    "utterance": "Combine multiple objects so that for each input, the value of a.b becomes a key and a.d becomes the value, returning one merged object, optionally nested under key x.",
    "expressions": [
      "[inputs | .a | { (.b): .d }] | add",
      "{ x: [inputs | .a | { (.b): .d }] | add }"
    ],
    "data": [
      {
        "input": [
          {
            "a": {
              "b": "c",
              "d": "e"
            }
          },
          {
            "a": {
              "b": "f",
              "d": "g"
            }
          }
        ],
        "output": {
          "c": "e",
          "f": "g"
        }
      },
      {
        "input": [
          {
            "a": {
              "b": "c",
              "d": "e"
            }
          },
          {
            "a": {
              "b": "f",
              "d": "g"
            }
          }
        ],
        "output": {
          "x": {
            "c": "e",
            "f": "g"
          }
        }
      }
    ],
    "identifier": 51491317
  },
  {
    "context": [
      "How can I get `123.123.123.123` using `dbUrl` with [jq](https://stedolan.github.io/jq/)?",
      "You don&#39;t need to look into a specific index, just use the `select()` expression do that for you, which will return the `@name` containing `dbUrl` and return its `@value`",
      "jq --raw-output '.project.property[] | select(.\"@name\"==\"dbUrl\") | .\"@value\"'",
      "If you want all the values of \"@value\" corresponding to \"@name\" being \"dbUrl\":",
      ".. | objects | select(.[\"@name\"] == \"dbUrl\") | .[\"@value\"]"
    ],
    "utterance": "Extract the value of '@value' from any object in the 'property' array where '@name' is 'dbUrl'.",
    "expressions": [
      ".project.property[] | select(.\"@name\"==\"dbUrl\") | .\"@value\"",
      ".. | objects | select(.[\"@name\"] == \"dbUrl\") | .[\"@value\"]"
    ],
    "data": [
      {
        "input": {
          "project": {
            "@basedir": ".",
            "property": [
              {
                "@environment": "env"
              },
              {
                "@name": "foo",
                "@value": "bar"
              },
              {
                "@name": "aaa",
                "@value": "bbb"
              },
              {
                "@name": "dbUrl",
                "@value": "123.123.123.123"
              }
            ]
          }
        },
        "output": "123.123.123.123"
      },
      {
        "input": {
          "project": {
            "@basedir": ".",
            "property": [
              {
                "@environment": "env"
              },
              {
                "@name": "foo",
                "@value": "bar"
              },
              {
                "@name": "dbUrl",
                "@value": "123.123.123.123"
              },
              {
                "@name": "aaa",
                "@value": "bbb"
              }
            ]
          }
        },
        "output": "123.123.123.123"
      }
    ],
    "identifier": 51516041
  },
  {
    "context": [
      "If there is a invalid URL, response.json is not available. I am getting error as below 2 times as I have parsed the $response 2 times",
      "if [ $status  = 200 ]; then",
      "  if [ -f $response ]; then",
      "    local name=$(cat $response | jq -r .name)",
      "    if [ $name = \"John\" ]; then",
      "      local address=$(cat $response | jq -r .address)",
      "      # Process response"
    ],
    "utterance": "Check if the HTTP request was successful and the response file exists before querying for the 'name' field equal to 'John'; extract 'address' if so.",
    "expressions": [
      ".name",
      ".address"
    ],
    "identifier": 51530795
  },
  {
    "context": [
      "I would only like the block that matches the ImageId I specify. Like so:",
      "If you want to *extract* only the one block:\r\n\r\n    jq --arg id ami-77777777 '.ImportImageTasks[] | select(.ImageId==$id)'",
      "If you want to *filter* the blocks, and return a document with the same form but all other `ImageImportTask` blocks removed:\r\n\r\n    jq --arg id ami-77777777 '.ImportImageTasks |= [.[] | select(.ImageId==$id)]'"
    ],
    "utterance": "Return the object(s) where ImageId equals ami-77777777.",
    "expressions": [
      ".ImportImageTasks[] | select(.ImageId==$id)",
      ".ImportImageTasks |= [.[] | select(.ImageId==$id)]"
    ],
    "data": [
      {
        "input": {
          "ImportImageTasks": [
            {
              "Architecture": "x86_64",
              "ImageId": "ami-99999999",
              "ImportTaskId": "import-ami-00000000",
              "LicenseType": "BYOL",
              "Platform": "Linux",
              "Status": "completed"
            },
            {
              "Architecture": "x86_64",
              "ImageId": "ami-88888888",
              "ImportTaskId": "import-ami-11111111",
              "LicenseType": "BYOL",
              "Platform": "Linux",
              "Status": "completed"
            },
            {
              "Architecture": "x86_64",
              "ImageId": "ami-77777777",
              "ImportTaskId": "import-ami-22222222",
              "LicenseType": "BYOL",
              "Platform": "Linux",
              "Status": "completed"
            }
          ]
        },
        "output": {
          "Architecture": "x86_64",
          "ImageId": "ami-77777777",
          "ImportTaskId": "import-ami-22222222",
          "LicenseType": "BYOL",
          "Platform": "Linux",
          "Status": "completed"
        }
      }
    ],
    "identifier": 51525419
  },
  {
    "context": [
      "As a result, I wanna get info per order including clientId as key, place_validation_time and execute_validation_time per order.",
      "I tried the following:",
      ".operations[] | select(.operationName==\"GetValue\") | {key: .orders[].clientId, place_validation_time: .orders[].validation_time.place, execute_validation_time: .orders[].validation_time.execute, batch_size: .batch_size}",
      "But it has an unexpected result for me, it combined all clientId with all variations of validation_time.place and validation_time.execute, so instead of 1 object per order I\u2019ve got 4 (for batch_size=2) e.g.",
      "Does anybody have ideas how to avoid it and get as a result 1 object per 1 order?",
      "The cartesian-product behavior is the result of including .orders[] at multiple places inside the object-construction expression.  Hoist it instead.  Assuming you want to select objects with .batch_size equal to \"2\", you could write:",
      ".operations[]\n| select(.operationName==\"GetValue\")\n| .batch_size as $batch_size\n| select($batch_size == \"2\")\n| .orders[]\n| {key: .clientId,\n   place_validation_time: .validation_time.place,\n   execute_validation_time: .validation_time.execute,\n   batch_size: $batch_size}",
      "If you have other items of interest at the .batch_size level, you would probably want to use a filter more like this:",
      ".operations[]\n| select(.operationName==\"GetValue\")\n| . as $it\n| select($it.batch_size == \"2\")\n| .orders[]\n| {key: .clientId,\n   place_validation_time: .validation_time.place,\n   execute_validation_time: .validation_time.execute,\n   batch_size: $it.batch_size}"
    ],
    "utterance": "Produce one result per order that includes clientId as key, place_validation_time, execute_validation_time, and batch_size for each order, only where batch_size equals \"2\".",
    "expressions": [
      ".operations[]\n| select(.operationName==\"GetValue\")\n| .batch_size as $batch_size\n| select($batch_size == \"2\")\n| .orders[]\n| {key: .clientId, place_validation_time: .validation_time.place, execute_validation_time: .validation_time.execute, batch_size: $batch_size}",
      ".operations[]\n| select(.operationName==\"GetValue\")\n| . as $it\n| select($it.batch_size == \"2\")\n| .orders[]\n| {key: .clientId, place_validation_time: .validation_time.place, execute_validation_time: .validation_time.execute, batch_size: $it.batch_size}"
    ],
    "data": [
      {
        "input": {
          "operations": [
            {
              "operationName": "GetValue",
              "batch_size": "2",
              "orders": [
                {
                  "clientId": "7836",
                  "validation_time": {
                    "place": "136",
                    "execute": "5379"
                  }
                },
                {
                  "clientId": "7837",
                  "validation_time": {
                    "place": "145",
                    "execute": "5401"
                  }
                }
              ]
            },
            {
              "operationName": "GetValue",
              "batch_size": "3",
              "orders": [
                {
                  "clientId": "7838",
                  "validation_time": {
                    "place": "122",
                    "execute": "5201"
                  }
                },
                {
                  "clientId": "7839",
                  "validation_time": {
                    "place": "122",
                    "execute": "5201"
                  }
                },
                {
                  "clientId": "7840",
                  "validation_time": {
                    "place": "122",
                    "execute": "5201"
                  }
                }
              ]
            }
          ]
        },
        "output": [
          {
            "key": "7836",
            "place_validation_time": "136",
            "execute_validation_time": "5379",
            "batch_size": "2"
          },
          {
            "key": "7837",
            "place_validation_time": "145",
            "execute_validation_time": "5401",
            "batch_size": "2"
          }
        ]
      }
    ],
    "identifier": 51515869
  },
  {
    "context": [
      "Say I have the following JSON:\r\n\r\n`{\"a\": 1, \"b\": 2, \"c\": 3}`",
      "I want to get the following output:\r\n\r\n    c 3\r\n    a 1",
      "Two things going - first, I am printing only two keys and values, and I am ordering in the way I want.",
      "With your input, the filter\r\n\r\n    ( {c}, {a} )\r\n    | to_entries[]\r\n    | \"\\(.key) \\(.value)\"\r\n\r\nproduces the desired output",
      "If the ordering of keys you want is specified by an array, $a, then you could write:\r\n\r\n    . as $in\r\n    | $a[]\r\n    | \"\\(.) \\($in[.])\"\r\n"
    ],
    "utterance": "Print only the keys 'c' and 'a' and their values, in that order, each on its own line, as key-value pairs separated by a space.",
    "expressions": [
      "( {c}, {a} ) | to_entries[] | \"\\(.key) \\(.value)\"",
      ". as $in | [\"c\",\"a\"][] | \"\\(.) \\($in[.])\""
    ],
    "data": [
      {
        "input": {
          "a": 1,
          "b": 2,
          "c": 3
        },
        "output": "c 3\na 1"
      }
    ],
    "identifier": 51562538
  },
  {
    "context": [
      "$ jq -n 'def f: $a; 1 as $a | f'",
      "jq: error: a/0 is not defined at <top-level>, line 1:",
      "In jq, the scoping of variables is defined lexically. With `f` defined as `$a`, `f` can only be evaluated as `$a` if `$a` is \"visible\" to `f`.",
      "It can also be achieved as illustrated by:",
      "jq -n '2 as $a | def f: $a; f'"
    ],
    "utterance": "Call a function that references a variable, where the variable is bound in the calling scope and accessible within the function.",
    "expressions": [
      "2 as $a | def f: $a; f",
      "def f($a): def g: $a; g; f(1)"
    ],
    "data": [
      {
        "input": null,
        "output": 2
      },
      {
        "input": null,
        "output": 1
      }
    ],
    "identifier": 51582008
  },
  {
    "context": [
      "I need to support variables all around to push changes to JSON",
      "changeField=.one.aaa",
      "changeValue=new-val",
      "This works:",
      "jq --arg changeValue $changeValue \".one.aaa = \\\"$changeValue\\\"\" some.json",
      "This does not:",
      "jq --arg changeField $changeField --arg changeValue $changeValue \"$changeField = \\\"$changeValue\\\"\" some.json",
      "If you want the dots to be treated as nesting separators",
      "jq --arg changeValue \"$changeValue\" \"$changeField\"'=$changeValue' <<<\"$inputJson\"",
      "...properly emits:",
      "{",
      "  \"one\": {",
      "    \"aaa\": \"new-val\"",
      "  }",
      "}"
    ],
    "utterance": "Update the field specified by the variable `.one.aaa` to the value `new-val`.",
    "expressions": [
      "$changeField=\"$changeField\"; $changeValue=\"$changeValue\"; jq --arg changeValue \"$changeValue\" \"$changeField\"'=$changeValue'"
    ],
    "data": [
      {
        "input": {
          "one": {
            "aaa": "old-val"
          }
        },
        "output": {
          "one": {
            "aaa": "new-val"
          }
        }
      }
    ],
    "identifier": 51545594
  },
  {
    "context": [
      "Here is the command whose output i want to save in a variable.",
      "echo '[{\"field\":\"fieldA\",\"bucket\":[\"a\",\"b\",\"c\"]},{\"field\":\"fieldB\",\"bucket\":[\"a\",\"b\",\"c\",\"d\"]}]' | jq -r '.[]|{field, bucketText: .bucket|join(\", \")}|join(\" found in bucket: \")'",
      "fieldA found in bucket: a, b, c",
      "fieldB found in bucket: a, b, c, d",
      "output=\"$(jq -r '.[]|{field, bucketText: .bucket|join(\", \")}|join(\" found in bucket: \")' <<< \"$input\")\""
    ],
    "utterance": "List each field with its corresponding buckets joined by commas, separated by ' found in bucket: '.",
    "expressions": [
      ".[] | {field, bucketText: .bucket | join(\", \")} | join(\" found in bucket: \")"
    ],
    "data": [
      {
        "input": [
          {
            "field": "fieldA",
            "bucket": [
              "a",
              "b",
              "c"
            ]
          },
          {
            "field": "fieldB",
            "bucket": [
              "a",
              "b",
              "c",
              "d"
            ]
          }
        ],
        "output": [
          "fieldA found in bucket: a, b, c",
          "fieldB found in bucket: a, b, c, d"
        ]
      }
    ],
    "identifier": 51564898
  },
  {
    "context": [
      "You could either format a JSON argument and use `--argjson`:",
      "$ jq --argjson args '[\"abc\",\"efg\"]' '[\"filename\"] += $args' <<< '{\"filename\":[]}'",
      "Or you could make `update_list` into an array, and loop:",
      "jq --argjson args \"$(printf '%s\\n' \"${update_list[@]}\" | jq -nR '[inputs]')\" '[\"filename\"] += $args'",
      "jq --arg args \"$update_list\" '[\"filename\"] += ($args|split(\",\")|map(fromjson))'"
    ],
    "utterance": "Add the elements 'abc' and 'efg', stored in a Bash variable, to the array under the 'filename' key.",
    "expressions": [
      ".[\"filename\"] += $args",
      ".[\"filename\"] += ($args|split(\",\")|map(fromjson))"
    ],
    "data": [
      {
        "input": {
          "##_Comment1": "Inputs",
          "filename": [
            "file1",
            "file2",
            "file3",
            "file4"
          ]
        },
        "output": {
          "##_Comment1": "Inputs",
          "filename": [
            "file1",
            "file2",
            "file3",
            "file4",
            "abc",
            "efg"
          ]
        }
      }
    ],
    "identifier": 51595356
  },
  {
    "context": [
      "is there a way of finding the right json object in \"address\" based on \"name\" (in wireless array) and \"interface\" (in address array) for every json object in \"wireless\" array and then assigning \"address\" to it?",
      "The final result should look like this:\n\n    {\n      \"name\": \"device\",\n      \"version\": \"1.0.0\",\n      \"wireless\": [\n        {\n          \"name\": \"wlan1_wifi\",\n          \"type\": \"5Ghz\",\n          \"ssid\": \"wifi\",\n          \"address\": \"10.1.2.3\"\n        },\n        {\n          \"name\": \"wlan2_link\",\n          \"type\": \"2Ghz\",\n          \"ssid\": \"link\",\n          \"address\": \"10.1.2.5\"\n        }\n      ]\n    }",
      "(INDEX(.address[]; .interface)) as $dict \n| {name: .name, version: .version, \nwireless: [.wireless[] | {name, address: ($dict[.name]|.address), type, ssid}]}",
      "If your jq has INDEX/2 (which was only made available AFTER jq 1.5 was released), you can simply use it to create a lookup table:\n\n    (INDEX(.address[]; .interface)) as $dict\n    | {name,\n       version,\n       wireless: (.wireless\n                  | map(. + {address: ($dict[.name]|.address) }) ) }"
    ],
    "utterance": "For every item in wireless, assign the address field from the matching object in address where interface equals the wireless name, so each wireless object includes its corresponding address.",
    "expressions": [
      "(INDEX(.address[]; .interface)) as $dict | {name: .name, version: .version, wireless: [.wireless[] | {name, address: ($dict[.name]|.address), type, ssid}]}",
      "(INDEX(.address[]; .interface)) as $dict | {name, version, wireless: (.wireless | map(. + {address: ($dict[.name]|.address) }) ) }",
      "(INDEX(.address[]; .interface)) as $dict | del(.address) | .wireless |= map(. + {address: ($dict[.name]|.address) })"
    ],
    "data": [
      {
        "input": {
          "name": "device",
          "version": "1.0.0",
          "address": [
            {
              "address": "10.1.2.3",
              "interface": "wlan1_wifi"
            },
            {
              "address": "10.1.2.5",
              "interface": "wlan2_link"
            },
            {
              "address": "10.1.2.4",
              "interface": "ether1"
            }
          ],
          "wireless": [
            {
              "name": "wlan1_wifi",
              "type": "5Ghz",
              "ssid": "wifi"
            },
            {
              "name": "wlan2_link",
              "type": "2Ghz",
              "ssid": "link"
            }
          ]
        },
        "output": {
          "name": "device",
          "version": "1.0.0",
          "wireless": [
            {
              "name": "wlan1_wifi",
              "type": "5Ghz",
              "ssid": "wifi",
              "address": "10.1.2.3"
            },
            {
              "name": "wlan2_link",
              "type": "2Ghz",
              "ssid": "link",
              "address": "10.1.2.5"
            }
          ]
        }
      }
    ],
    "identifier": 51558701
  },
  {
    "context": [
      ".apps.app | sort_by(.allocatedMB + .allocatedVCores * 10000) | reverse | .[] | select(.state == \"RUNNING\") | {name, allocatedMB, allocatedVCores, user, id, trackingUrl}",
      ".apps.app | map(select(.state == \"RUNNING\")) | sort_by(.allocatedMB + .allocatedVCores * 10000) | reverse[] | {name, allocatedMB, allocatedVCores, user, id, trackingUrl}"
    ],
    "utterance": "List running applications, sorted in descending order by the sum of allocatedMB and 10000 times allocatedVCores, showing name, allocatedMB, allocatedVCores, user, id, and trackingUrl.",
    "expressions": [
      ".apps.app | sort_by(.allocatedMB + .allocatedVCores * 10000) | reverse | .[] | select(.state == \"RUNNING\") | {name, allocatedMB, allocatedVCores, user, id, trackingUrl}",
      ".apps.app | map(select(.state == \"RUNNING\")) | sort_by(.allocatedMB + .allocatedVCores * 10000) | reverse[] | {name, allocatedMB, allocatedVCores, user, id, trackingUrl}"
    ],
    "identifier": 51626001
  },
  {
    "context": [
      "I want to join the key that lies in several identically structured documents, the file `new.json`...",
      "after each jq execution, the expected result will be the addition to the database of the new key in the corresponding array element:",
      "jq -s --argfile db db.json 'map($db[] * .[]) | unique_by(.foo)' new.json",
      "After modifying your db.json and new.json to make them valid JSON, and adding the following filter to a file (update.jq):",
      "reduce range(0;length) as $i (.; .[$i].foo += $new[$i].foo )",
      "jq --argfile new new.json -f update.jq db.json"
    ],
    "utterance": "For each element in the arrays, add the key and value from the corresponding element in another file so each object contains its original keys and the new key.",
    "expressions": [
      "jq -s --argfile db db.json 'map($db[] * .[]) | unique_by(.foo)' new.json",
      "jq --argfile new new.json 'reduce range(0;length) as $i (.; .[$i].foo += $new[$i].foo )' db.json"
    ],
    "data": [
      {
        "input": [
          [
            {
              "foo": {
                "key_1": "value_1.1",
                "key_2": "value_1.2"
              }
            },
            {
              "foo": {
                "key_1": "value_2.1",
                "key_2": "value_2.2"
              }
            }
          ],
          [
            {
              "foo": {
                "key_n": "value_1.N"
              }
            },
            {
              "foo": {
                "key_n": "value_2.N"
              }
            }
          ]
        ],
        "output": [
          {
            "foo": {
              "key_1": "value_1.1",
              "key_2": "value_1.2",
              "key_n": "value_1.N"
            }
          },
          {
            "foo": {
              "key_1": "value_2.1",
              "key_2": "value_2.2",
              "key_n": "value_2.N"
            }
          }
        ]
      }
    ],
    "identifier": 51609844
  },
  {
    "context": [
      "extracting just the filenames from the below JSON file.",
      "expected output:\n\n    [filename1.gz,filename2.gz,filename3.gz,filename4.gz]",
      "jq --compact-output '[.files[].name]'"
    ],
    "utterance": "Extract the list of all values for the 'name' field from each object in the 'files' array.",
    "expressions": [
      "[.files[].name]"
    ],
    "data": [
      {
        "input": {
          "files": [
            {
              "name": "filename1.gz",
              "StartDate": "2018-07-09T11:00:00-04:00",
              "EndDate": "2018-07-09T12:00:00-04:00"
            },
            {
              "name": "filename2.gz",
              "StartDate": "2018-07-09T10:00:00-04:00",
              "EndDate": "2018-07-09T11:00:00-04:00"
            },
            {
              "name": "filename3.gz",
              "StartDate": "2018-07-09T09:00:00-04:00",
              "EndDate": "2018-07-09T10:00:00-04:00"
            },
            {
              "name": "filename4.gz",
              "StartDate": "2018-07-09T07:00:00-04:00",
              "EndDate": "2018-07-09T08:00:00-04:00"
            }
          ]
        },
        "output": [
          "filename1.gz",
          "filename2.gz",
          "filename3.gz",
          "filename4.gz"
        ]
      }
    ],
    "identifier": 51619475
  },
  {
    "context": [
      "I have a json file like this:\r\n\r\n    {\"caller_id\":\"123321\",\"cust_name\":\"abc\"}\r\n    {\"caller_id\":\"123443\",\"cust_name\":\"def\"}\r\n    {\"caller_id\":\"123321\",\"cust_name\":\"abc\"}\r\n    {\"caller_id\":\"234432\",\"cust_name\":\"ghi\"}\r\n    {\"caller_id\":\"123321\",\"cust_name\":\"abc\"}\r\n    ....\r\n",
      "jq -s 'unique_by(.field1)'",
      "if you simply change your command to jq -s 'unique_by(.caller_id)' it will give you desired result containing unique & sorted objects based on caller_id key. It will ensure in result you have atleast & atmost one object for each caller_id.",
      "If the file consists of a sequence (stream) of JSON objects, then a very simple way to produce a stream of the distinct objects would be to use the invocation:\r\n\r\n    jq -s `unique[]`",
      "A similar alternative would be:\r\n\r\n    jq -n `[inputs] | unique[]`"
    ],
    "utterance": "Keep exactly one object for each distinct caller_id, removing duplicate objects with the same caller_id.",
    "expressions": [
      "jq -s 'unique_by(.caller_id)[]'",
      "jq -s 'unique[]'",
      "jq -n '[inputs] | unique[]'"
    ],
    "data": [
      {
        "input": [
          {
            "caller_id": "123321",
            "cust_name": "abc"
          },
          {
            "caller_id": "123443",
            "cust_name": "def"
          },
          {
            "caller_id": "123321",
            "cust_name": "abc"
          },
          {
            "caller_id": "234432",
            "cust_name": "ghi"
          },
          {
            "caller_id": "123321",
            "cust_name": "abc"
          }
        ],
        "output": [
          {
            "caller_id": "123321",
            "cust_name": "abc"
          },
          {
            "caller_id": "123443",
            "cust_name": "def"
          },
          {
            "caller_id": "234432",
            "cust_name": "ghi"
          }
        ]
      }
    ],
    "identifier": 51619317
  },
  {
    "context": [
      "To display the name and the status I use the following commands, where $input holds the above JSON:",
      "output=$(jq '.[] | \"\\(.name) \\(.status)\"' <<< \"$input\")",
      "echo $output",
      "This produces:",
      "\"A: ACTIVE\" \"B: ACTIVE\" \"C: ACTIVE\" \"D: ACTIVE\" \"E: ACTIVE\" \"F: ACTIVE\" \"G: ACTIVE\"",
      "How do I ensure each iteration produces one new line, like so:",
      "\"A: ACTIVE\"",
      "\"B: ACTIVE\"",
      "\"C: ACTIVE\"",
      "\"D: ACTIVE\"",
      "\"E: ACTIVE\"",
      "\"F: ACTIVE\"",
      "\"G: ACTIVE\""
    ],
    "utterance": "Produce each object's name and status as a separate line of output in the format \"<name>: <status>\".",
    "expressions": [
      ".[] | \"\\(.name): \\(.status)\""
    ],
    "data": [
      {
        "input": [
          {
            "type": "A",
            "id": "A",
            "name": "A",
            "message": "OK",
            "updateDate": "2018-07-31T10:55:14.813Z",
            "createDate": "2018-07-31T08:01:32.164Z",
            "status": "ACTIVE"
          },
          {
            "type": "B",
            "id": "B",
            "name": "B",
            "message": "OK",
            "updateDate": "2018-07-31T10:55:16.803Z",
            "createDate": "2018-07-31T08:01:34.171Z",
            "status": "ACTIVE"
          },
          {
            "type": "C",
            "id": "C",
            "name": "C",
            "message": "OK",
            "updateDate": "2018-07-31T10:55:18.607Z",
            "createDate": "2018-07-31T08:01:37.181Z",
            "status": "ACTIVE"
          },
          {
            "type": "D",
            "id": "D",
            "name": "D",
            "message": "OK",
            "updateDate": "2018-07-31T10:55:20.877Z",
            "createDate": "2018-07-31T08:01:38.185Z",
            "status": "ACTIVE"
          },
          {
            "type": "E",
            "id": "E",
            "name": "E",
            "message": "OK",
            "updateDate": "2018-07-31T10:55:18.615Z",
            "createDate": "2018-07-31T08:01:44.207Z",
            "status": "ACTIVE"
          },
          {
            "type": "F",
            "id": "F",
            "name": "F",
            "message": "OK",
            "updateDate": "2018-07-31T10:55:19.131Z",
            "createDate": "2018-07-31T08:01:44.207Z",
            "status": "ACTIVE"
          },
          {
            "type": "G",
            "id": "G",
            "name": "G",
            "message": "OK",
            "updateDate": "2018-07-31T10:55:18.326Z",
            "createDate": "2018-07-31T08:01:46.212Z",
            "status": "ACTIVE"
          }
        ],
        "output": [
          "\"A: ACTIVE\"",
          "\"B: ACTIVE\"",
          "\"C: ACTIVE\"",
          "\"D: ACTIVE\"",
          "\"E: ACTIVE\"",
          "\"F: ACTIVE\"",
          "\"G: ACTIVE\""
        ]
      }
    ],
    "identifier": 51616832
  },
  {
    "context": [
      "What id like to achieve is to retain the full JSON output with the changed value",
      "jq --arg match \"VAL2CHANGE\" \\\n   --arg replace \"VALHASBEENCHANGED\" \\\n  '.Par |= map(if .Value == $match then (.Value=$replace) else . end)' \\\n  <in.json",
      "To more comprehensively replace a string anywhere it may be in a nested data structure, you can use the `walk` function -- which will be in the standard library in jq 1.6, but can be manually pulled in in 1.5:",
      "walk(if . == $match then $replace else . end)' <in.json"
    ],
    "utterance": "Replace the value of the object in the 'Par' array where 'Value' is 'VAL2CHANGE' with 'VALHASBEENCHANGED', preserving the entire structure.",
    "expressions": [
      ".Par |= map(if .Value == $match then (.Value=$replace) else . end)",
      "walk(if . == $match then $replace else . end)"
    ],
    "data": [
      {
        "input": {
          "Par": [
            {
              "Key": "12345L",
              "Value": "https://100.100.100.100:100",
              "UseLastValue": true
            },
            {
              "Key": "12345S",
              "Value": "VAL2CHANGE",
              "UseLastValue": true
            },
            {
              "Key": "12345T",
              "Value": "HAPPY-HELLO",
              "UseLastValue": true
            }
          ],
          "CANCOPY": false,
          "LOGFILE": [
            "HELPLOG"
          ]
        },
        "output": {
          "Par": [
            {
              "Key": "12345L",
              "Value": "https://100.100.100.100:100",
              "UseLastValue": true
            },
            {
              "Key": "12345S",
              "Value": "VALHASBEENCHANGED",
              "UseLastValue": true
            },
            {
              "Key": "12345T",
              "Value": "HAPPY-HELLO",
              "UseLastValue": true
            }
          ],
          "CANCOPY": false,
          "LOGFILE": [
            "HELPLOG"
          ]
        }
      }
    ],
    "identifier": 51658522
  },
  {
    "context": [
      "I have the following json output available and i need to extract the value of href which is the https URL using jq processor.",
      "to access a field having special characters like `:` in their names, do a proper quoting of the field as below.",
      "jq --raw-output '.links.\"urn:somedomainid:follow\".href'"
    ],
    "utterance": "Extract the value of the href field under links.\"urn:somedomainid:follow\".",
    "expressions": [
      ".links.\"urn:somedomainid:follow\".href"
    ],
    "data": [
      {
        "input": {
          "links": {
            "urn:somedomainid:follow": {
              "href": "https://abc.somedomain.com/ula/login?service=IDGW&channel=WEB&usecaseid=a0b51311-d14b-4733-9e6b-ba5f5deec05f&opco=DE&nonce=89e31cde-fecc-41e1-91d6-1f9f84f9c136&acr_values=explicit&scopes=phone_number&returnUrl=https%3A%2F%2Fidgw.somedomain.com%2Fauthorize%23state%3Da0b51311-d14b-4733-9e6b-ba5f5deec05f",
              "type": "text/html"
            }
          },
          "context": "FOLLOW"
        },
        "output": "https://abc.somedomain.com/ula/login?service=IDGW&channel=WEB&usecaseid=a0b51311-d14b-4733-9e6b-ba5f5deec05f&opco=DE&nonce=89e31cde-fecc-41e1-91d6-1f9f84f9c136&acr_values=explicit&scopes=phone_number&returnUrl=https%3A%2F%2Fidgw.somedomain.com%2Fauthorize%23state%3Da0b51311-d14b-4733-9e6b-ba5f5deec05f"
      }
    ],
    "identifier": 51631441
  },
  {
    "context": [
      "And I want to add the corresponding values to a JSON array",
      "Before adding the values, I want to check if the element already exists and skip if it does.",
      "ID=(1 2 3 4 1)",
      "VALUES=(\"/path1\" \"/path2\" \"/path3\" \"/path4\" \"/path1\")",
      "jq -n --arg id \"$ID\" --arg values \"$VALUES\" '\n  # emit a dictionary\n  def set(s): reduce s as $x ({};\n    .[$x | (type[0:1] + tostring)] = $x);\n \n  # distinct entities in the stream s\n  def distinct(s): set(s)[];\n\n  [$id, $values]\n  | map( split(\"\\n\"))\n  | [distinct(transpose[])]\n  | map( {Id: .[0], Path: .[1]} )\n'",
      "We use `set/1` and `distinct/1` rather than `unique` mainly to ensure that the ordering is retained as the requirements specify, but also to avoid the `sort` that `unique` entails."
    ],
    "utterance": "Combine two arrays of IDs and paths into an array of objects with Id and Path, skipping duplicates, preserving their order.",
    "expressions": [
      "[$id, $values]\n| map( split(\"\\n\"))\n| [distinct(transpose[])]\n| map( {Id: .[0], Path: .[1]} )"
    ],
    "data": [
      {
        "input": {
          "ID": [
            "1",
            "2",
            "3",
            "4",
            "1"
          ],
          "VALUES": [
            "/path1",
            "/path2",
            "/path3",
            "/path4",
            "/path1"
          ]
        },
        "output": [
          {
            "Id": "1",
            "Path": "/path1"
          },
          {
            "Id": "2",
            "Path": "/path2"
          },
          {
            "Id": "3",
            "Path": "/path3"
          },
          {
            "Id": "4",
            "Path": "/path4"
          }
        ]
      }
    ],
    "identifier": 51668189
  },
  {
    "context": [
      "I'm getting a \"parse error\" when I split a text line on multiple lines and show the JSON file on screen with the command `jq . words.json`.",
      "But when I split the value \"one two three four five\" on two lines and run the same command I get a parse error",
      "> parse error: Invalid string: control characters from U+0000 through\n> U+001F must be escaped at line 3, column 20",
      "You have to escape end of line in JSON:\n\n    {\n      \"words\" : \"one two\\nthree four five\"\n    }",
      "That's because the JSON format is invalid. It should look like this:\n\n    {\n        \"words\" : \"one two \\nthree four five\"\n    }",
      "The way `jq` flags this error may be counterintuitive, but the error in the JSON *precedes* the indicated quote-mark.\n\nIf the error is non-obvious, **it may be that an end-quote is missing on the prior key or value**.  In this case, the value that matches the criteria `U+0000 through U+001F` could be `U+000A`, which is the [line feed](https://en.wikipedia.org/wiki/Newline) character in [ASCII](https://en.wikipedia.org/wiki/ASCII).\n\nIn the case of this question, the line feed was inserted intentionally.  But, unescaped, this is [invalid JSON](https://stackoverflow.com/a/27516892/86967)."
    ],
    "utterance": "Display the value of the key 'words' that contains an explicit newline character within the string value.",
    "expressions": [
      ".words"
    ],
    "data": [
      {
        "input": {
          "words": "one two\nthree four five"
        },
        "output": "one two\nthree four five"
      }
    ],
    "identifier": 51628133
  },
  {
    "context": [
      "I am having a heck of a time trying to figure out how to select the values for id, attributes.name, attributes.albumName, and attributes.artistName",
      "$ jq '.results.songs.data[0] | {id, attributes.name } ' t",
      "With your sample JSON as input, the following invocation:",
      "jq '{id, name: .attributes.name }' input.json",
      "The filter above is short for:",
      "{\"id\" : .id, \"name\": .attributes.name }",
      "In any case, the keys must be appropriately specified."
    ],
    "utterance": "Extract the id and the name field from the attributes object from the first song in the results.songs.data array.",
    "expressions": [
      ".results.songs.data[0] | {id, name: .attributes.name}",
      ".results.songs.data[0] | {id: .id, name: .attributes.name}"
    ],
    "data": [
      {
        "input": {
          "results": {
            "songs": {
              "data": [
                {
                  "id": "152471393",
                  "attributes": {
                    "previews": [
                      {
                        "url": "https://audio-ssl.itunes.apple.com/apple-assets-us-std-000001/AudioPreview71/v4/7d/c5/68/7dc56849-29b8-bd90-2bb1-51750e479569/mzaf_4742389090778091050.plus.aac.p.m4a"
                      }
                    ],
                    "artwork": {
                      "width": 1449,
                      "height": 1449,
                      "url": "https://is5-ssl.mzstatic.com/image/thumb/Music/v4/7d/01/56/7d0156be-12cd-8724-a0ca-727b1013a81d/source/{w}x{h}bb.jpeg",
                      "bgColor": "ddcfc4",
                      "textColor1": "010100",
                      "textColor2": "422f10",
                      "textColor3": "2d2a27",
                      "textColor4": "614f34"
                    },
                    "artistName": "Gnarls Barkley",
                    "url": "https://itunes.apple.com/us/album/crazy/152471339?i=152471393",
                    "discNumber": 1,
                    "genreNames": [
                      "Alternative",
                      "Music",
                      "R&B/Soul",
                      "Rock",
                      "Soul",
                      "Hip-Hop/Rap",
                      "Rap",
                      "Hip-Hop",
                      "Adult Alternative",
                      "Neo-Soul",
                      "Alternative Rap",
                      "Underground Rap"
                    ],
                    "durationInMillis": 178387,
                    "releaseDate": "2006-03-13",
                    "name": "Crazy",
                    "isrc": "USAT20611041",
                    "albumName": "St. Elsewhere",
                    "playParams": {
                      "id": "152471393",
                      "kind": "song"
                    },
                    "trackNumber": 2
                  }
                }
              ]
            }
          }
        },
        "output": {
          "id": "152471393",
          "name": "Crazy"
        }
      }
    ],
    "identifier": 51566939
  }
]