[
  {
    "context": [
      "Given:\r\n\r\n**a.json**:\r\n\r\n```js\r\n{\"a\": 1}\r\n```\r\n\r\n**b.json**:\r\n\r\n```js\r\n{\"b\": 2}\r\n```\r\nRequired contents of **merged.json**:\r\n\r\n```js\r\n{\"a\": 1, \"b\": 2}\r\n```\r\n",
      "What's the `jq` syntax to merge **a.json** and **b.json** into **merged.json**?",
      "you can use the -s option, which is usually fine, but for very large JSON objects, it might be more economical to use `inputs`, e.g. with `reduce`:\r\n\r\n    jq -n 'reduce inputs as $in (null; . + $in)' a.json b.json"
    ],
    "utterance": "Merge two files so that all top-level keys from both are combined in the output object.",
    "expressions": [
      "jq -n 'reduce inputs as $in (null; . + $in)' a.json b.json"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1
          },
          {
            "b": 2
          }
        ],
        "output": {
          "a": 1,
          "b": 2
        }
      }
    ],
    "identifier": 63457122
  },
  {
    "context": [
      "I want to remove with jq all elements of the dictionary `dic` which are also in the dictionary `remove` with the value true.",
      "You don't need anything other than JQ for that.",
      "[.remove | path(.[] | select(.))] as $p | .dic |= delpaths($p)",
      "(.remove | with_entries(select(.value == true))) as $remove\n| .dic |= with_entries(select($remove[.key] | not))"
    ],
    "utterance": "Remove all keys from 'dic' that are present in 'remove' with the value true.",
    "expressions": [
      "[.remove | path(.[] | select(.))] as $p | .dic |= delpaths($p)",
      "(.remove | with_entries(select(.value == true))) as $remove | .dic |= with_entries(select($remove[.key] | not))"
    ],
    "data": [
      {
        "input": {
          "dic": {
            "a": "",
            "b": "",
            "c": "",
            "d": ""
          },
          "remove": {
            "b": true,
            "c": false,
            "d": true
          }
        },
        "output": {
          "dic": {
            "a": "",
            "c": ""
          },
          "remove": {
            "b": true,
            "c": false,
            "d": true
          }
        }
      }
    ],
    "identifier": 63472280
  },
  {
    "context": [
      "I want to get a value that meets (key=RED && attr1=\"aaaa\" && attr2=\"bbbb\")",
      "jq -r 'with_entries(select([.key] | inside([\"RED\"]))) | .[] | .[] | select(.attr1==\"aaaa\") | select(.attr2==\"bbbb\") | .attr3' test.json",
      "The following program does exactly the same thing and is way shorter.",
      ".RED[] | select(.attr1 == \"aaaa\" and .attr2 == \"bbbb\") .attr3"
    ],
    "utterance": "Extract the attr3 value where the top-level key is RED and attr1 is \"aaaa\" and attr2 is \"bbbb\"",
    "expressions": [
      ".RED[] | select(.attr1 == \"aaaa\" and .attr2 == \"bbbb\") .attr3"
    ],
    "data": [
      {
        "input": {
          "RED": [
            {
              "attr1": "aaaa",
              "attr2": "bbbb",
              "attr3": "cccc"
            },
            {
              "attr1": "aaaa",
              "attr2": "dddd",
              "attr3": "eeee"
            }
          ],
          "WHITE": [
            {
              "attr1": "aaaa",
              "attr2": "bbbb",
              "attr3": "cccc"
            },
            {
              "attr1": "aaaa",
              "attr2": "dddd",
              "attr3": "eeee"
            }
          ]
        },
        "output": "cccc"
      }
    ],
    "identifier": 63463982
  },
  {
    "context": [
      "I want to add:\n\"description\": \"5 years less than 30\"\nat the same level of \"details\" if \"age\" is equal to \"25\" and then print the result:",
      "(.components[] | select(.details.age == \"25\")) += { \"description\": \"5 years less than 30\" }",
      ".components |= \n  map(if .details.age==\"25\" then .description = \"5 years less than 30\" else . end)"
    ],
    "utterance": "Add a description key with value \"5 years less than 30\" to each component whose details.age is \"25\".",
    "expressions": [
      "(.components[] | select(.details.age == \"25\")) += { \"description\": \"5 years less than 30\" }",
      ".components |= map(if .details.age==\"25\" then .description = \"5 years less than 30\" else . end)"
    ],
    "data": [
      {
        "input": {
          "family": {
            "surname": "Smith"
          },
          "components": [
            {
              "name": "John",
              "details": {
                "hair": "brown",
                "eyes": "brown",
                "age": "56"
              },
              "role": "father"
            },
            {
              "name": "Mary",
              "details": {
                "hair": "blonde",
                "eyes": "green",
                "age": "45"
              },
              "role": "mother"
            },
            {
              "name": "George",
              "details": {
                "hair": "blonde",
                "eyes": "brown",
                "age": "25"
              },
              "role": "child"
            }
          ]
        },
        "output": {
          "family": {
            "surname": "Smith"
          },
          "components": [
            {
              "name": "John",
              "details": {
                "hair": "brown",
                "eyes": "brown",
                "age": "56"
              },
              "role": "father"
            },
            {
              "name": "Mary",
              "details": {
                "hair": "blonde",
                "eyes": "green",
                "age": "45"
              },
              "role": "mother"
            },
            {
              "name": "George",
              "details": {
                "hair": "blonde",
                "eyes": "brown",
                "age": "25"
              },
              "role": "child",
              "description": "5 years less than 30"
            }
          ]
        }
      }
    ],
    "identifier": 63488357
  },
  {
    "context": [
      "I want to sort this data structure by the object keys (easy with `-S` and sort the object values (the arrays) by the 'foo' property.",
      "I can sort them with\n\n```\njq -S '\n  . as $in\n  | keys[]\n  | . as $k\n  | $in[$k] | sort_by(.foo)\n    ' < test.json\n```\n\n... but that loses the keys.",
      "Maybe this?\n\n    jq -S '.[] |= sort_by(.foo)'",
      "A suggestion I got in a private message elsewhere was to use\n\n    jq -S 'with_entries(.value |= sort_by(.foo))'",
      "If for some reason using the `-S` command-line option is not a satisfactory option, you can also perform the by-key sort using the `to_entries | sort_by(.key) | from_entries` idiom. So a complete solution to the problem would be:\n\n```\n.[] |= sort_by(.foo)\n| to_entries | sort_by(.key) | from_entries\n```"
    ],
    "utterance": "Sort the top-level object's keys alphabetically and sort each associated array by the 'foo' property.",
    "expressions": [
      ".[] |= sort_by(.foo)",
      "with_entries(.value |= sort_by(.foo))",
      ".[] |= sort_by(.foo) | to_entries | sort_by(.key) | from_entries"
    ],
    "data": [
      {
        "input": {
          "": [
            {
              "foo": "d"
            },
            {
              "foo": "g"
            },
            {
              "foo": "f"
            }
          ],
          "c": [
            {
              "foo": "abc"
            },
            {
              "foo": "def"
            }
          ],
          "e": [
            {
              "foo": "xyz"
            },
            {
              "foo": "def"
            }
          ],
          "ab": [
            {
              "foo": "def"
            },
            {
              "foo": "abc"
            }
          ]
        },
        "output": {
          "": [
            {
              "foo": "d"
            },
            {
              "foo": "f"
            },
            {
              "foo": "g"
            }
          ],
          "ab": [
            {
              "foo": "abc"
            },
            {
              "foo": "def"
            }
          ],
          "c": [
            {
              "foo": "abc"
            },
            {
              "foo": "def"
            }
          ],
          "e": [
            {
              "foo": "def"
            },
            {
              "foo": "xyz"
            }
          ]
        }
      }
    ],
    "identifier": 63477501
  },
  {
    "context": [
      "I wanted to extract Tags values, whose keys are Name: For eg:",
      "I wanted to get only kubernetes-dynamic-pvc-claim1 and kubernetes-dynamic-pvc-claim2.",
      "Also, how do I get output with Size and VOlumetype on their side as below ?",
      "I wanted results like:",
      "kubernetes-dynamic-pvc-claim1  100  io1",
      "kubernetes-dynamic-pvc-claim2  200  gp2",
      ".Volumes[] | ",
      ".Size as $s | ",
      ".VolumeType as $v | ",
      ".Tags[] | select(.Key == \"Name\").Value as $k | ",
      "[$k, $s, $v] | join(\" \")"
    ],
    "utterance": "Extract the value for the Tag where Key is 'Name', and output it alongside the corresponding Size and VolumeType for each volume.",
    "expressions": [
      ".Volumes[] | .Size as $s | .VolumeType as $v | .Tags[] | select(.Key == \"Name\").Value as $k | [$k, $s, $v] | join(\" \")"
    ],
    "data": [
      {
        "input": {
          "Volumes": [
            {
              "Attachments": [],
              "Encrypted": true,
              "Size": 100,
              "SnapshotId": "",
              "State": "available",
              "Tags": [
                {
                  "Key": "Name",
                  "Value": "kubernetes-dynamic-pvc-claim1"
                },
                {
                  "Key": "kubernetes.io/created-for/pv/name",
                  "Value": "pvc-claim1"
                }
              ],
              "VolumeType": "io1",
              "MultiAttachEnabled": false
            },
            {
              "Attachments": [],
              "Encrypted": true,
              "Size": 200,
              "SnapshotId": "",
              "State": "available",
              "Tags": [
                {
                  "Key": "kubernetes.io/created-for/pv/name",
                  "Value": "pvc-claim2"
                },
                {
                  "Key": "Name",
                  "Value": "kubernetes-dynamic-pvc-claim2"
                }
              ],
              "VolumeType": "gp2",
              "MultiAttachEnabled": false
            }
          ]
        },
        "output": [
          "kubernetes-dynamic-pvc-claim1 100 io1",
          "kubernetes-dynamic-pvc-claim2 200 gp2"
        ]
      }
    ],
    "identifier": 63486554
  },
  {
    "context": [
      "I want to have an output like \r\n\r\n    \"ALLOCATED=872c08ee-9b21-4b26-9550-c2ffb4a1ad59,79970c9a-b0ba-4cde-a7e6-16b61641a7b8\"",
      "I tried to use below, but I don't know how to remove the line with status as \"BOOTING\".",
      ".amphorae[] | \"\\(.status)=\\(.id),\\(.loadbalancer_id)\"",
      ".amphorae[1] | \"\\(.status)=\\(.id),\\(.loadbalancer_id)\"",
      ".amphorae | map(select(.status == \"ALLOCATED\"))[] | \"\\(.status)=\\(.id),\\(.loadbalancer_id)\""
    ],
    "utterance": "Produce a string in the form ALLOCATED=<id>,<loadbalancer_id> for entries where status is ALLOCATED.",
    "expressions": [
      ".amphorae | map(select(.status == \"ALLOCATED\"))[] | \"\\(.status)=\\(.id),\\(.loadbalancer_id)\""
    ],
    "data": [
      {
        "input": {
          "amphorae_links": [],
          "amphorae": [
            {
              "status": "BOOTING",
              "loadbalancer_id": null,
              "created_at": "2020-06-23T08:56:56",
              "vrrp_id": null,
              "id": "6d66935e-6d39-40c9-bb0d-dd6a734dc77b"
            },
            {
              "status": "ALLOCATED",
              "loadbalancer_id": "79970c9a-b0ba-4cde-a7e6-16b61641a7b8",
              "created_at": "2020-06-25T06:41:56",
              "vrrp_id": 1,
              "id": "872c08ee-9b21-4b26-9550-c2ffb4a1ad59"
            }
          ]
        },
        "output": "ALLOCATED=872c08ee-9b21-4b26-9550-c2ffb4a1ad59,79970c9a-b0ba-4cde-a7e6-16b61641a7b8"
      }
    ],
    "identifier": 63432348
  },
  {
    "context": [
      "I am trying to use `jq` to remove keys from the first file that exist in the second file.",
      "Given:",
      "**a.json**:",
      "{ \"a\": 1, \"b\": 2 }",
      "**b.json**:",
      "{ \"b\": true }",
      "Required contents of **diff.json**:",
      "{ \"a\": 1 }",
      "What's the `jq` syntax to subtract these two JSONs?",
      "$ jq 'delpaths([input | path(.[])])' a.json b.json > diff.json",
      "$ cat diff.json",
      "{ \"a\": 1 }"
    ],
    "utterance": "Remove all top-level keys from the first object that also exist in the second object.",
    "expressions": [
      "delpaths([input | path(.[])])"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1,
            "b": 2
          },
          {
            "b": true
          }
        ],
        "output": {
          "a": 1
        }
      }
    ],
    "identifier": 63507581
  },
  {
    "context": [
      "I am looking for an approach where i have to extract the first 500 objects from the main json and send it in one rest query and then next 500 object in second rest query and so on.",
      "< array.json jq -c '\n  def batch($n): length as $l | range(0;length;$n) as $i | .[$i: $i+n];\n  batch(500)\n' | while read -r json\ndo\n    echo \"$json\" | curl -X POST -H \"Content-Type: application/json\" -d -@ ....\ndone\n",
      "Modified `jq` filter to pack the JSON payload as an array of objects (credit [peak's answer](https://stackoverflow.com/a/63482061/5291015)). The earlier version `jq -c '.[]' json` might not work as the individual chunk of lines passed at a time doesn't represent a valid JSON.",
      "jq -c '.[0:500]' temp.json | xargs -I {} curl <REST Server URL with temp.json as input> \"Content-Type: application/json\" -d '{}'",
      "jq -c '.[]' | split -l500"
    ],
    "utterance": "Extract successive batches of 500 objects from an input and output each batch as an array.",
    "expressions": [
      "def batch($n): length as $l | range(0;length;$n) as $i | .[$i:$i+$n]; batch(500)",
      "range(0;length;500) as $i | .[$i: $i+500]",
      ".[0:500]",
      ".[500:1000]"
    ],
    "data": [
      {
        "input": [
          {
            "field": {
              "empID": "sapid",
              "location": "India"
            }
          },
          {
            "field": {
              "empID": "sapid",
              "location": "India"
            }
          },
          {
            "field": {
              "empID": "sapid",
              "location": "India"
            }
          },
          {
            "field": {
              "empID": "sapid",
              "location": "India"
            }
          },
          {
            "field": {
              "empID": "sapid",
              "location": "India"
            }
          },
          {
            "field": {
              "empID": "sapid",
              "location": "India"
            }
          }
        ],
        "output": [
          [
            {
              "field": {
                "empID": "sapid",
                "location": "India"
              }
            },
            {
              "field": {
                "empID": "sapid",
                "location": "India"
              }
            },
            {
              "field": {
                "empID": "sapid",
                "location": "India"
              }
            },
            {
              "field": {
                "empID": "sapid",
                "location": "India"
              }
            },
            {
              "field": {
                "empID": "sapid",
                "location": "India"
              }
            },
            {
              "field": {
                "empID": "sapid",
                "location": "India"
              }
            }
          ]
        ]
      }
    ],
    "identifier": 63481172
  },
  {
    "context": [
      "I want to filter out any records where the message.action == \"foo\" IF message.action even exists.",
      "but I still want to be able to display { message: \"hi\" }",
      "select(.message | type == \"object\" and has(\"action\") and .action == \"foo\" | not)",
      "jq 'select((.message.action? // \"foo\") != \"foo\")'"
    ],
    "utterance": "Filter out records where the 'message' property has an 'action' key equal to 'foo', but include records where 'action' does not exist.",
    "expressions": [
      "select(.message | type == \"object\" and has(\"action\") and .action == \"foo\" | not)",
      "select((.message.action? // \"foo\") != \"foo\")"
    ],
    "data": [
      {
        "input": {
          "message": "hi"
        },
        "output": {
          "message": "hi"
        }
      },
      {
        "input": {
          "message": {
            "action": "foo"
          }
        }
      },
      {
        "input": {
          "message": {
            "action": "not foo"
          }
        },
        "output": {
          "message": {
            "action": "not foo"
          }
        }
      }
    ],
    "identifier": 63510772
  },
  {
    "context": [
      "jq '.DatabaseName = $TOKEN' connector.json|sponge connector.json",
      "jq --arg token \"$TOKEN\" '.DatabaseName = $token' connector.json",
      "jq --arg token \"$TOKEN\" '.awsIAMCred = \"hello\" | .DatabaseName = $token' connector.json"
    ],
    "utterance": "Update the value of DatabaseName to the shell variable TOKEN, and optionally set awsIAMCred to \"hello\".",
    "expressions": [
      "jq --arg token \"$TOKEN\" '.DatabaseName = $token' connector.json",
      "jq --arg token \"$TOKEN\" '.awsIAMCred = \"hello\" | .DatabaseName = $token' connector.json"
    ],
    "data": [
      {
        "input": {
          "awsIAMCred": "replaceme",
          "DatabaseName": "replaceme"
        },
        "output": {
          "awsIAMCred": "hello",
          "DatabaseName": "mouse"
        }
      }
    ],
    "identifier": 63523379
  },
  {
    "context": [
      "How can I get the \"auth-server-url\" value?",
      "The following should work -\r\n\r\n`cat test.json | jq &#39;.&quot;auth-server-url&quot;&#39;`",
      "To avoid the use of cat, and catch [special characters](https://github.com/stedolan/jq/issues/140) use;\r\n```\r\njq &#39;.[&quot;auth-server-url&quot;]&#39; &lt; test.json\r\n```"
    ],
    "utterance": "Select the value of the key 'auth-server-url' whose name contains hyphens.",
    "expressions": [
      ".\"auth-server-url\"",
      ".[\"auth-server-url\"]"
    ],
    "data": [
      {
        "input": {
          "realm": "somerealm",
          "auth-server-url": "http://someserver:8080/auth/"
        },
        "output": "http://someserver:8080/auth/"
      }
    ],
    "identifier": 63525523
  },
  {
    "context": [
      "# cat test.json | jq --arg keyvar \"$var\" '.servers.$[keyvar].monitoredServerHealth.healthState'",
      "$ jq --arg keyvar \"$var\" '.servers | .[$keyvar].monitoredServerHealth.healthState' input.json",
      "jq --arg keyvar \"$var\" '.servers.\"\\($keyvar)\".monitoredServerHealth.healthState' input.json"
    ],
    "utterance": "Access the value of servers[\"2\"].monitoredServerHealth.healthState using a shell variable for the server key.",
    "expressions": [
      ".servers | .[$keyvar].monitoredServerHealth.healthState",
      ".servers.\"\\($keyvar)\".monitoredServerHealth.healthState"
    ],
    "data": [
      {
        "input": {
          "currentServerId": 1,
          "isCurrentServerAvailable": true,
          "isClusterOwner": false,
          "clusterOwnerServerId": "2",
          "numInvalidEventMessages": "0",
          "numInvalidoperationalStateMessages": "0",
          "servers": {
            "1": {
              "isAvailableViaServerObjective": true,
              "eventMessagesPendingInDb": "0",
              "neo4jClusterRole": "slave",
              "monitoredServerHealth": null
            },
            "2": {
              "isAvailableViaServerObjective": true,
              "eventMessagesPendingInDb": "0",
              "neo4jClusterRole": "master",
              "monitoredServerHealth": {
                "serverId": 2,
                "healthState": "ALIVE",
                "healthCount": 1,
                "serverIdAsString": "2",
                "serverUid": "*"
              }
            },
            "3": {
              "isAvailableViaServerObjective": true,
              "eventMessagesPendingInDb": "0",
              "neo4jClusterRole": "slave",
              "monitoredServerHealth": null
            }
          }
        },
        "output": "ALIVE"
      }
    ],
    "identifier": 63556272
  },
  {
    "context": [
      "I got below JSON example content.",
      "I would like to have content as below",
      "403add1f-25d9-4a24-99ff-12c5559fecfa#79970c9a-b0ba-4cde-a7e6-16b61641a7b8,ranj-b0ba-4cde-a7e6-16b61641a7b8",
      "I have tried to use below, however, I want to concatenate the id into 1 line instead of having 2 lines.",
      ".pools[] | \"\\(.id),\\(.loadbalancers[] | .id)\"",
      "jq -r '.pools[] | .id + \"#\" + ( [.loadbalancers[].id] | join(\",\"))'"
    ],
    "utterance": "Produce a single line per pool combining its id, a # character, and a comma-separated list of its loadbalancer ids.",
    "expressions": [
      ".pools[] | .id + \"#\" + ([.loadbalancers[].id] | join(\",\"))"
    ],
    "data": [
      {
        "input": {
          "pools": [
            {
              "id": "403add1f-25d9-4a24-99ff-12c5559fecfa",
              "loadbalancers": [
                {
                  "id": "79970c9a-b0ba-4cde-a7e6-16b61641a7b8"
                },
                {
                  "id": "ranj-b0ba-4cde-a7e6-16b61641a7b8"
                }
              ]
            }
          ],
          "pools_links": []
        },
        "output": "403add1f-25d9-4a24-99ff-12c5559fecfa#79970c9a-b0ba-4cde-a7e6-16b61641a7b8,ranj-b0ba-4cde-a7e6-16b61641a7b8"
      }
    ],
    "identifier": 63553334
  },
  {
    "context": [
      "You can select the key `categoryId` for each object in the array by applying the selector: `curl -s https://api.scalablepress.com/v2/categories | jq 'map(.categoryId)'`",
      "Combining everything, you can achieve what you\u2019re looking for with a one-liner:\n\n`curl -s https://api.scalablepress.com/v2/categories | jq -r 'map(.categoryId) | .[]'`",
      "Even better, you can antislurp first, and then select the key you\u2019re looking for: `curl -s https://api.scalablepress.com/v2/categories | jq -r '.[] | .categoryId'`",
      "curl -s \"$CATURL\" | jq -rc '.[] | .categoryId'",
      "$ ./pullcat.sh\naprons\nbackpacks\nbeanies\nbracelet\ncoaster\ncutting-board\ndress-shirts\nduffel-bags\nearring\nfull-brim-hats\ngeneric-dropoff\nhats\nhoodies\ninfant-shirts\nladies-dress-shirts\nladies-dresses\nladies-long-sleeve\nladies-pants\nladies-performance-shirts\nladies-polos\nladies-short-sleeve\nladies-tank-tops\nlarge-bags\n..."
    ],
    "utterance": "List all category IDs from the API, including those that contain hyphens.",
    "expressions": [
      ".[] | .categoryId",
      "map(.categoryId) | .[]"
    ],
    "identifier": 63556984
  },
  {
    "context": [
      "Calling `jq` once per id is always going to be slow. Don&#39;t do that -- call jq just once, and have it match against the full set.",
      "You can accomplish that by passing the entire comma-separated list of ids into your one copy of jq, and letting jq itself do the work of splitting that string into individual items (and then putting them in a dictionary for fast access)",
      "For example:\r\n\r\n```\r\npid=\"24885,73648,38758,8377,747\"\r\njq --arg pidListStr \"$pid\" '\r\n  ($pidListStr | [split(\",\")[] | {(.): true}] | add) as $pidDict |\r\n  .page[] | select($pidDict[.id | tostring]) | .url\r\n' <<<\"$pagejson\"\r\n```",
      "The solution can then be written as follows:\r\n```\r\n  ($pidListStr | [splits(\" *, *\") | {(.): true}] | add) as $pidDict\r\n  | ($pidDict|length) as $n\r\n  | first_n(.page[] | select($pidDict[.id | tostring]) | .url; $n)\r\n```"
    ],
    "utterance": "Extract the url fields for all objects in the page array whose id matches any of the ids in a given list of 700-1000 known ids.",
    "expressions": [
      "jq --arg pidListStr \"$pid\" '($pidListStr | [split(\",\")[] | {(.): true}] | add) as $pidDict | .page[] | select($pidDict[.id | tostring]) | .url'",
      "($pidListStr | [splits(\" *, *\") | {(.): true}] | add) as $pidDict | ($pidDict|length) as $n | first_n(.page[] | select($pidDict[.id | tostring]) | .url; $n)"
    ],
    "data": [
      {
        "input": {
          "page": [
            {
              "url": "url_1",
              "id": 24885
            },
            {
              "url": "url_2",
              "id": 8377
            },
            {
              "url": "url_3",
              "id": 32641
            },
            {
              "url": "url_4",
              "id": 747
            }
          ]
        },
        "output": [
          "url_1",
          "url_2",
          "url_4"
        ]
      }
    ],
    "identifier": 63540687
  },
  {
    "context": [
      "I basically want a single array with all the child event arrays, but with their parent objects embedded into them.",
      "Copy all fields except **events** from the root to each *event*, and put resulting objects into an array.",
      "jq -n '[ inputs | .events[] + del(.events) ]'",
      "Almost same logic as Oguz's answer, using `with_entries()` to remove events from root and adding the fields alone",
      "jq -n '[ inputs | with_entries(select(.key != \"events\")) + (.events[]) ]'"
    ],
    "utterance": "Produce a single array where each event object includes all its parent's fields except events, merged into each event.",
    "expressions": [
      "jq -n '[ inputs | .events[] + del(.events) ]'",
      "jq -n '[ inputs | with_entries(select(.key != \"events\")) + (.events[]) ]'"
    ],
    "data": [
      {
        "input": [
          {
            "group": "A",
            "name": "abc",
            "events": [
              {
                "id": "54209",
                "message": "foobar 1"
              },
              {
                "id": "76548",
                "message": "foobar 2"
              }
            ]
          },
          {
            "group": "B",
            "name": "def",
            "events": [
              {
                "id": "54593",
                "message": "foobar 3"
              },
              {
                "id": "20359",
                "message": "foobar 4"
              }
            ]
          }
        ],
        "output": [
          {
            "group": "A",
            "name": "abc",
            "id": "54209",
            "message": "foobar 1"
          },
          {
            "group": "A",
            "name": "abc",
            "id": "76548",
            "message": "foobar 2"
          },
          {
            "group": "B",
            "name": "def",
            "id": "54593",
            "message": "foobar 3"
          },
          {
            "group": "B",
            "name": "def",
            "id": "20359",
            "message": "foobar 4"
          }
        ]
      }
    ],
    "identifier": 63578959
  },
  {
    "context": [
      "Using `jq`, I'm trying to display such a list:\r\n\r\n    161 tcp sg-22e04e44\r\n    22 tcp 0.0.0.0/0\r\n    -1 icmp 0.0.0.0/0",
      "The `CidrIP` is not present for `udp` record. If you want to alternate between `.GroupId` and `CidrIp`, you can do an alternation like\r\n\r\n    .SecurityGroups[].IpPermissions[] |\r\n    .FromPort as $port          |\r\n    .IpProtocol as $prot        |\r\n    .IpRanges as $ip            |\r\n    .UserIdGroupPairs as $group |\r\n    [\r\n      ($port|tostring),\r\n      ($prot),\r\n      (select($ip|length) | $ip[].CidrIp) //\r\n      (select($group|length) | $group[].GroupId) //\r\n      empty\r\n    ] |\r\n    @tsv",
      "produces an output like you wanted\r\n\r\n    161\tudp\tsg-22e04e44\r\n    22\ttcp\t0.0.0.0/0\r\n    -1\ticmp\t0.0.0.0/0"
    ],
    "utterance": "List each permission with its FromPort, IpProtocol, and either CidrIp if present or GroupId if CidrIp is missing.",
    "expressions": [
      ".SecurityGroups[].IpPermissions[] |\n.FromPort as $port |\n.IpProtocol as $prot |\n.IpRanges as $ip |\n.UserIdGroupPairs as $group |\n[\n  ($port|tostring),\n  ($prot),\n  (select($ip|length) | $ip[].CidrIp) //\n  (select($group|length) | $group[].GroupId) //\n  empty\n] |\n@tsv"
    ],
    "data": [
      {
        "input": {
          "SecurityGroups": [
            {
              "Description": "SG for ssh-proxy server",
              "GroupName": "ssh-proxy-SG",
              "IpPermissions": [
                {
                  "FromPort": 161,
                  "IpProtocol": "udp",
                  "IpRanges": [],
                  "Ipv6Ranges": [],
                  "PrefixListIds": [],
                  "ToPort": 161,
                  "UserIdGroupPairs": [
                    {
                      "GroupId": "sg-22e04e44",
                      "UserId": "XXXXXXXXXXXX"
                    }
                  ]
                },
                {
                  "FromPort": 22,
                  "IpProtocol": "tcp",
                  "IpRanges": [
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ],
                  "Ipv6Ranges": [],
                  "PrefixListIds": [],
                  "ToPort": 22,
                  "UserIdGroupPairs": []
                },
                {
                  "FromPort": -1,
                  "IpProtocol": "icmp",
                  "IpRanges": [
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ],
                  "Ipv6Ranges": [],
                  "PrefixListIds": [],
                  "ToPort": -1,
                  "UserIdGroupPairs": []
                }
              ],
              "OwnerId": "XXXXXXXXXXXX",
              "GroupId": "sg-4f1d8a35",
              "IpPermissionsEgress": [
                {
                  "IpProtocol": "-1",
                  "IpRanges": [
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ],
                  "Ipv6Ranges": [],
                  "PrefixListIds": [],
                  "UserIdGroupPairs": []
                }
              ],
              "Tags": [
                {
                  "Key": "Name",
                  "Value": "ssh-proxy-SG"
                }
              ],
              "VpcId": "vpc-d3131fbe"
            }
          ]
        },
        "output": "161\tudp\tsg-22e04e44\n22\ttcp\t0.0.0.0/0\n-1\ticmp\t0.0.0.0/0"
      }
    ],
    "identifier": 63561477
  },
  {
    "context": [
      "I get the following output:\r\n\r\n    null\t-1\t0.0.0.0/0\r\n    22\ttcp\t0.0.0.0/0\r\n\r\nI&#39;d like to remove the null from the output, how can it be done?",
      "Add a [fallback][1] for the `.FromPort` key:\r\n```\r\n.FromPort // &quot;&quot;\r\n```",
      "So the command becomes;\r\n```\r\n.SecurityGroups[].IpPermissions[] | [ (.FromPort // &quot;&quot; ?), .IpProtocol, .IpRanges[].CidrIp ] | @tsv\r\n```"
    ],
    "utterance": "Output an empty string instead of null for FromPort in each IpPermissions entry when generating tab-separated values, so that lines start with a blank when FromPort is absent.",
    "expressions": [
      ".SecurityGroups[].IpPermissions[] | [ (.FromPort // \"\"), .IpProtocol, .IpRanges[].CidrIp ] | @tsv",
      ".SecurityGroups[].IpPermissions[] | [ (.FromPort // \"\")?, .IpProtocol, .IpRanges[].CidrIp ] | @tsv"
    ],
    "data": [
      {
        "input": {
          "SecurityGroups": [
            {
              "Description": "launch-wizard-6 created 2018-10-25T13:59:20.092+03:00",
              "GroupName": "launch-wizard-6",
              "IpPermissions": [
                {
                  "IpProtocol": "-1",
                  "IpRanges": [
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ],
                  "Ipv6Ranges": [],
                  "PrefixListIds": [],
                  "UserIdGroupPairs": []
                },
                {
                  "FromPort": 22,
                  "IpProtocol": "tcp",
                  "IpRanges": [
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ],
                  "Ipv6Ranges": [],
                  "PrefixListIds": [],
                  "ToPort": 22,
                  "UserIdGroupPairs": []
                }
              ],
              "OwnerId": "XXXXXXXXXXXX",
              "GroupId": "sg-054368f50a6b4fea4",
              "IpPermissionsEgress": [
                {
                  "IpProtocol": "-1",
                  "IpRanges": [
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ],
                  "Ipv6Ranges": [
                    {
                      "CidrIpv6": "::/0"
                    }
                  ],
                  "PrefixListIds": [],
                  "UserIdGroupPairs": []
                }
              ],
              "VpcId": "vpc-6ea82a08"
            }
          ]
        },
        "output": "\t-1\t0.0.0.0/0\n22\ttcp\t0.0.0.0/0"
      }
    ],
    "identifier": 63562998
  },
  {
    "context": [
      "When I then try to extract all the chassis ID's I cannot get them without error:",
      "jq: error (at <stdin>:1): Cannot iterate over string (\"/redfish/v...",
      "Select arrays and apply **.[][]** to only them.",
      "select(type == \"array\") .[][]",
      "Or, shorter:",
      "arrays[][]"
    ],
    "utterance": "Output all values of '@odata.id' from embedded objects inside arrays, ignoring non-array inputs, without errors.",
    "expressions": [
      "select(type == \"array\") .[][]",
      "arrays[][]"
    ],
    "data": [
      {
        "input": [
          "/redfish/v1/Chassis",
          "/redfish/v1/$metadata#ChassisCollection.ChassisCollection",
          "#ChassisCollection.ChassisCollection",
          "ChassisCollection",
          [
            {
              "@odata.id": "/redfish/v1/Chassis/14"
            },
            {
              "@odata.id": "/redfish/v1/Chassis/9"
            },
            {
              "@odata.id": "/redfish/v1/Chassis/1"
            },
            {
              "@odata.id": "/redfish/v1/Chassis/25"
            },
            {
              "@odata.id": "/redfish/v1/Chassis/5"
            },
            {
              "@odata.id": "/redfish/v1/Chassis/26"
            },
            {
              "@odata.id": "/redfish/v1/Chassis/6"
            },
            {
              "@odata.id": "/redfish/v1/Chassis/22"
            }
          ],
          28
        ],
        "output": [
          {
            "@odata.id": "/redfish/v1/Chassis/14"
          },
          {
            "@odata.id": "/redfish/v1/Chassis/9"
          },
          {
            "@odata.id": "/redfish/v1/Chassis/1"
          },
          {
            "@odata.id": "/redfish/v1/Chassis/25"
          },
          {
            "@odata.id": "/redfish/v1/Chassis/5"
          },
          {
            "@odata.id": "/redfish/v1/Chassis/26"
          },
          {
            "@odata.id": "/redfish/v1/Chassis/6"
          },
          {
            "@odata.id": "/redfish/v1/Chassis/22"
          }
        ]
      }
    ],
    "identifier": 63579320
  },
  {
    "context": [
      "docker node inspect $NODE_ID | jq -r '.[] | {node:.ID, ip:.Status.Addr}'",
      "done | jq -s",
      "In nodes.sh, rather than invoking jq without any argument, invoke it as `jq -s .`."
    ],
    "utterance": "Aggregate multiple outputs into an array by collecting all streamed objects.",
    "expressions": [
      "jq -s ."
    ],
    "identifier": 63581946
  },
  {
    "context": [
      "From this JSON I want to create new objects by combining fields from objects which have **status: 2** and their **files** which also have the same pair, **status: 2**.",
      "So, I am expecting a JSON array as below.",
      "[",
      "  {",
      "    \"id\": \"4\",",
      "    \"name\": \"AA_2\",",
      "    \"file_filename\": \"63ab85fef2412ce80ae8bd018497d8bf.csv\",",
      "    \"file_status\": 2",
      "  }",
      "]",
      "By applying **[]** operator to **files** twice, you're running into a combinatorial explosion. That needs to be avoided, for example:",
      "[ .[] | select(.status == \"2\") | {id, name} + (.files[] | select(.status == \"2\") | {file_filename: .filename, file_status: .status}) ]"
    ],
    "utterance": "Extract objects where status is 2 and include only their files with status 2, outputting id, name, file_filename, and file_status.",
    "expressions": [
      "[ .[] | select(.status == \"2\") | {id, name} + (.files[] | select(.status == \"2\") | {file_filename: .filename, file_status: .status}) ]"
    ],
    "data": [
      {
        "input": [
          {
            "id": "1",
            "name": "AA_1",
            "total": "100002",
            "files": [
              {
                "filename": "8665b987ab48511eda9e458046fbc42e.csv",
                "filename_original": "some.csv",
                "status": "3",
                "total": "100002",
                "time": "2020-08-24 23:25:49"
              }
            ],
            "status": "3",
            "created": "2020-08-24 23:25:49",
            "filenames": "8665b987ab48511eda9e458046fbc42e.csv",
            "is_append": "0",
            "is_deleted": "0",
            "comment": null
          },
          {
            "id": "4",
            "name": "AA_2",
            "total": "43806503",
            "files": [
              {
                "filename": "1b4812fe634938928953dd40db1f70b2.csv",
                "filename_original": "other.csv",
                "status": "3",
                "total": "21903252",
                "time": "2020-08-24 23:33:43"
              },
              {
                "filename": "63ab85fef2412ce80ae8bd018497d8bf.csv",
                "filename_original": "some.csv",
                "status": "2",
                "total": 0,
                "time": "2020-08-24 23:29:30"
              }
            ],
            "status": "2",
            "created": "2020-08-24 23:35:51",
            "filenames": "1b4812fe634938928953dd40db1f70b2.csv&&63ab85fef2412ce80ae8bd018497d8bf.csv",
            "is_append": "0",
            "is_deleted": "0",
            "comment": null
          }
        ],
        "output": [
          {
            "id": "4",
            "name": "AA_2",
            "file_filename": "63ab85fef2412ce80ae8bd018497d8bf.csv",
            "file_status": 2
          }
        ]
      }
    ],
    "identifier": 63572261
  },
  {
    "context": [
      "First, I want to delete unnecessary keys and re-format the JSON. I want to have the result look like following ...",
      "[.[] | {Region: .Header.Region, Tenants: [.Body[] | {tenantUuid, tenantState}] }]",
      "Of course, it would be more efficient to perform the selection earlier in the pipeline -- by all means, have at it!"
    ],
    "utterance": "Create a new array where each object has a 'Region' key from the original Header.Region and a 'Tenants' array containing objects with only 'tenantUuid' and 'tenantState' from each Body entry.",
    "expressions": [
      "[.[] | {Region: .Header.Region, Tenants: [.Body[] | {tenantUuid, tenantState}] }]"
    ],
    "data": [
      {
        "input": [
          {
            "Header": {
              "Region": "DC1"
            },
            "Body": [
              {
                "agentMetaInfoDtos": [],
                "avgTraffic": 682,
                "minAgentVersion": "1.191.0.20180101-000000",
                "standardAgentVersion": null,
                "tenantState": "ACTIVE",
                "tenantUuid": "DC1-Tenant1"
              },
              {
                "agentMetaInfoDtos": [],
                "avgTraffic": 957,
                "minAgentVersion": "1.185.0.20180101-000000",
                "standardAgentVersion": null,
                "tenantState": "DISABLED",
                "tenantUuid": "DC1-Tenant2"
              }
            ]
          },
          {
            "Header": {
              "Region": "DC2"
            },
            "Body": [
              {
                "agentMetaInfoDtos": [],
                "avgTraffic": 690,
                "minAgentVersion": "1.163.0.20180101-000000",
                "standardAgentVersion": null,
                "tenantState": "ACTIVE",
                "tenantUuid": "DC2-t4-p1"
              },
              {
                "agentMetaInfoDtos": [],
                "avgTraffic": 2441,
                "minAgentVersion": "1.161.0.20180101-000000",
                "standardAgentVersion": null,
                "tenantState": "ACTIVE",
                "tenantUuid": "DC2-t5-p2"
              }
            ]
          },
          {
            "Header": {
              "Region": "DC3"
            },
            "Body": [
              {
                "agentMetaInfoDtos": [],
                "avgTraffic": 2046,
                "minAgentVersion": "1.169.0.20180101-000000",
                "standardAgentVersion": null,
                "tenantState": "ACTIVE",
                "tenantUuid": "DC3-r1-p1"
              },
              {
                "agentMetaInfoDtos": [],
                "avgTraffic": 0,
                "minAgentVersion": null,
                "standardAgentVersion": null,
                "tenantState": "FORSAKEN",
                "tenantUuid": "DC3-r2-d1"
              }
            ]
          }
        ],
        "output": [
          {
            "Region": "DC1",
            "Tenants": [
              {
                "tenantState": "ACTIVE",
                "tenantUuid": "DC1-Tenant1"
              },
              {
                "tenantState": "DISABLED",
                "tenantUuid": "DC1-Tenant2"
              }
            ]
          },
          {
            "Region": "DC2",
            "Tenants": [
              {
                "tenantState": "ACTIVE",
                "tenantUuid": "DC2-t4-p1"
              },
              {
                "tenantState": "ACTIVE",
                "tenantUuid": "DC2-t5-p2"
              }
            ]
          },
          {
            "Region": "DC3",
            "Tenants": [
              {
                "tenantState": "ACTIVE",
                "tenantUuid": "DC3-r1-p1"
              },
              {
                "tenantState": "FORSAKEN",
                "tenantUuid": "DC3-r2-d1"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 63505416
  },
  {
    "context": [
      "This is the output I want:\r\n\r\n    [1,2,3]",
      "But I get\r\n\r\n    1\r\n    2\r\n    3\r\n\r\nwith \r\n\r\n    [.items[] ] [] | [.id, .name]  | .[0]",
      "All you need is below. The `-c/--compact-output` flag will put the output in a single line\r\n\r\n    jq -c '[.items[].id]'"
    ],
    "utterance": "Extract the id values from all objects in the items array and return them as a single array.",
    "expressions": [
      "[.items[].id]",
      "jq -c '[.items[].id]'"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "id": 1,
              "name": "one"
            },
            {
              "id": 2,
              "name": "two"
            },
            {
              "id": 3,
              "name": "tre"
            }
          ]
        },
        "output": [
          1,
          2,
          3
        ]
      }
    ],
    "identifier": 63596570
  },
  {
    "context": [
      "So **using only `jq`**, how can I sum up the `width` fields from this file, _e.g._, to make sure they don't exceed 100%?",
      "Here is the solution I ended up with:",
      "jq 'map(.width | sub(\"%\"; \"\")? | tonumber) | add' columns.json",
      "A shorter alternative:",
      "map(.width[:-1] | tonumber?) | add"
    ],
    "utterance": "Sum all width fields that end with a percent sign, ignoring entries without width, and return the total as a number.",
    "expressions": [
      "map(.width | sub(\"%\"; \"\")? | tonumber) | add",
      "map(.width[:-1] | tonumber?) | add"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Column A",
            "width": "33%"
          },
          {
            "name": "Column B",
            "width": "33%"
          },
          {
            "name": "Column C",
            "width": "33%"
          },
          {
            "name": "Column D",
            "visible": false
          }
        ],
        "output": 99
      }
    ],
    "identifier": 63597198
  },
  {
    "context": [
      "All that i need is to just to extract the value in the `access_token` .. Currently in the above script, i get an empty string after using jq-parser",
      "when i directly print this way, it works `echo $TOKEN_JSON_RESPONSE|jq '.access_token\u2019`",
      "ACCESS_TOKEN=$(echo $TOKEN_JSON_RESPONSE | jq -j '.access_token')",
      "jq -jn \"$TOKEN_JSON_RESPONSE|.access_token\""
    ],
    "utterance": "Extract the value of the access_token key from a response object.",
    "expressions": [
      ".access_token",
      "-j '.access_token'",
      "-jn \"$TOKEN_JSON_RESPONSE|.access_token\""
    ],
    "data": [
      {
        "input": {
          "access_token": "eyJxxxxxxxx",
          "token_type": "bearer",
          "expires_in": 3600
        },
        "output": "eyJxxxxxxxx"
      }
    ],
    "identifier": 63611639
  },
  {
    "context": [
      "I need to transform this ec2 tags (array)  \r\n\r\n    [ \r\n        { Key: 'Name', Value: 'xxx' },\r\n        { Key: 'role', Value: 'yyy' } \r\n    ]\r\n\r\nto \r\n\r\n    { \r\n     name : 'xxx',\r\n     role : 'yyy'\r\n    }\r\n\r\nusing jq and node.js. Could you help please",
      "const tags = [ \r\n    { Key: 'Name', Value: 'xxx' },\r\n    { Key: 'role', Value: 'yyy' } \r\n];\r\nconst obj = Object.fromEntries(tags.map(({ Key, Value }) => [Key, Value]));"
    ],
    "utterance": "Convert an array of objects with 'Key' and 'Value' properties into an object mapping lowercase key names to their values, e.g., map 'Name'/'role' keys to an object with keys 'name' and 'role'.",
    "expressions": [
      "map({ ( .Key | ascii_downcase ) : .Value }) | add"
    ],
    "data": [
      {
        "input": [
          {
            "Key": "Name",
            "Value": "xxx"
          },
          {
            "Key": "role",
            "Value": "yyy"
          }
        ],
        "output": {
          "name": "xxx",
          "role": "yyy"
        }
      }
    ],
    "identifier": 63621648
  },
  {
    "context": [
      "Essentially trying to extract \"value\" field from each \"fieldValues\" object and group them by \"id\"",
      ".elements[] | {id, values: [ .fieldValues[].value] }",
      "the following filter will produce the output as shown below, that is, a stream of valid JSON values that is similar to the allegedly expected output included in the Q."
    ],
    "utterance": "For each object in 'elements', list its 'id' and collect all 'value' fields from its 'fieldValues' array under a 'values' key.",
    "expressions": [
      ".elements[] | {id, values: [ .fieldValues[].value] }"
    ],
    "data": [
      {
        "input": {
          "elements": [
            {
              "type": "CustomObjectData",
              "id": "2185",
              "fieldValues": [
                {
                  "type": "FieldValue",
                  "id": "169",
                  "value": "9/6/2017 12:00:00 AM"
                },
                {
                  "type": "FieldValue",
                  "id": "190",
                  "value": "ABC"
                }
              ]
            },
            {
              "type": "CustomObjectData",
              "id": "2186",
              "contactId": "13",
              "fieldValues": [
                {
                  "type": "FieldValue",
                  "id": "169",
                  "value": "8/31/2017 12:00:00 AM"
                },
                {
                  "type": "FieldValue",
                  "id": "190",
                  "value": "DEF"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "id": "2185",
            "values": [
              "9/6/2017 12:00:00 AM",
              "ABC"
            ]
          },
          {
            "id": "2186",
            "values": [
              "8/31/2017 12:00:00 AM",
              "DEF"
            ]
          }
        ]
      }
    ],
    "identifier": 63627472
  },
  {
    "context": [
      "here is the origin test.json:\r\n```\r\n[\r\n  {\r\n    \"gate\": [\r\n      {\r\n        \"pro1\": \"1\"\r\n      }\r\n    ],\r\n    \"home\": [\r\n      {\r\n        \"mem1\": \"1\"\r\n      }\r\n    ],\r\n    \"holder\": \"1\"\r\n  }\r\n]\r\n```",
      "And i wish to be like this after insert:\r\n```\r\n[\r\n  {\r\n    \"gate\": [\r\n      {\r\n        \"pro1\": \"1\"\r\n      }\r\n    ],\r\n    \"home\": [\r\n      {\r\n        \"mem1\": \"1\"\r\n      }\r\n    ],\r\n    \"holder\": \"1\"\r\n  },\r\n  {\r\n    \"gate\": [\r\n      {\r\n        \"pro1\": \"2\"\r\n      }\r\n    ],\r\n    \"home\": [\r\n      {\r\n        \"mem1\": \"2\"\r\n      }\r\n    ],\r\n    \"holder\": \"1\"\r\n  }\r\n]\r\n```",
      "You can add items to the end of a list with the `+` operator. So in your case:\r\n\r\n```\r\njq '.+[{\"gate\":[{\"pro1\": \"2\"}], \"home\":[{\"mem1\": \"2\"}],\"holder\": \"1\"}]' input.json\r\n```\r\n",
      "The `.` takes the existing input, which is an array. The `+[ {...} ]` concatenates it with another array of one object. If you want to put the new item(s) at the start instead of the end, swap it round: `[ {...} ]+.`"
    ],
    "utterance": "Append an object containing arrays (with gate:[{pro1: '2'}], home:[{mem1: '2'}], holder: '1') to an existing top-level array.",
    "expressions": [
      ".+[{\"gate\":[{\"pro1\": \"2\"}], \"home\":[{\"mem1\": \"2\"}],\"holder\": \"1\"}]"
    ],
    "data": [
      {
        "input": [
          {
            "gate": [
              {
                "pro1": "1"
              }
            ],
            "home": [
              {
                "mem1": "1"
              }
            ],
            "holder": "1"
          }
        ],
        "output": [
          {
            "gate": [
              {
                "pro1": "1"
              }
            ],
            "home": [
              {
                "mem1": "1"
              }
            ],
            "holder": "1"
          },
          {
            "gate": [
              {
                "pro1": "2"
              }
            ],
            "home": [
              {
                "mem1": "2"
              }
            ],
            "holder": "1"
          }
        ]
      }
    ],
    "identifier": 63613080
  },
  {
    "context": [
      "How would I *only* select each `.pattern` that starts with `/v6/` ?",
      "jq '.. .pattern? // empty | select(test(\"^/v6/\"))' /tmp/all.json",
      "Or similarly with `startswith`."
    ],
    "utterance": "Extract all values of the 'pattern' key that start with /v6/.",
    "expressions": [
      ".. .pattern? // empty | select(test(\"^/v6/\"))",
      ".. .pattern? // empty | select(startswith(\"/v6/\"))"
    ],
    "data": [
      {
        "input": {
          "payload": {
            "groups": [
              {
                "pattern": "/v6/",
                "groups": [
                  {
                    "pattern": "something/",
                    "groups": [
                      {
                        "pattern": "somethingElse/",
                        "groups": [
                          {
                            "pattern": "{specialPattern:[0-9]+}/",
                            "groups": [],
                            "routes": [
                              {
                                "type": "variable",
                                "pattern": "/v6/notImportant/{specialPattern:[0-9]+}/",
                                "methods": {}
                              }
                            ]
                          }
                        ]
                      }
                    ]
                  }
                ]
              }
            ]
          }
        },
        "output": [
          "/v6/",
          "/v6/notImportant/{specialPattern:[0-9]+}/"
        ]
      }
    ],
    "identifier": 63633913
  },
  {
    "context": [
      "I need to get the name of first component with DOWN status (\"Configuration converted\" in above json).",
      "How can I get the name (key) of component? (\"Configuration converted\")",
      "You could use `to_entries` function to convert the objects within `.components` into key/value pairs and provide an expression that selects the first object matching the condition and retrieve its key",
      ".components | \nto_entries  | \nmap(select(.value.status == \"DOWN\"))[0].key",
      "You can use `to_entries` to get the key/values of your components , then select the first one with down status:",
      "first(.components | to_entries | .[] | select( .value.status == \"DOWN\") | .key)"
    ],
    "utterance": "Return the name of the first component whose status is DOWN.",
    "expressions": [
      ".components | to_entries | map(select(.value.status == \"DOWN\"))[0].key",
      "first(.components | to_entries | .[] | select(.value.status == \"DOWN\") | .key)"
    ],
    "data": [
      {
        "input": {
          "status": "DOWN",
          "components": {
            "ping": {
              "status": "UP",
              "details": {
                "version": "1.0.0",
                "description": "dobre application",
                "name": "SO-3113"
              }
            },
            "bridge.lock": {
              "status": "UP",
              "details": {
                "description": "test1"
              }
            },
            "Configuration converted": {
              "status": "DOWN",
              "details": {
                "description": "test2"
              }
            },
            "app started": {
              "status": "DOWN",
              "details": {
                "description": "test3"
              }
            }
          }
        },
        "output": "Configuration converted"
      }
    ],
    "identifier": 63635568
  },
  {
    "context": [
      "I\u2019m interested in parsing the satellites array in the above JSON (extracted below) and returning two numbers: The number of satellites, and the number of satellites used. For example: `7 12`",
      "$ jq -r '.sky[].satellites | ( [ .[] | select(.used == true) ] | length ), length'",
      "$ jq -r '.sky[].satellites | ( [ .[] | select(.used == true) ] | length | tostring) + \" \" + (length|tostring)'"
    ],
    "utterance": "Return both the count of elements in the 'satellites' array and the count of those where 'used' is true.",
    "expressions": [
      ".sky[].satellites | ( [ .[] | select(.used == true) ] | length ), length",
      ".sky[].satellites | ( [ .[] | select(.used == true) ] | length | tostring) + \" \" + (length|tostring)"
    ],
    "data": [
      {
        "input": {
          "class": "POLL",
          "time": "2020-08-24T07:01:31.690Z",
          "active": 1,
          "tpv": [
            {
              "class": "TPV",
              "tag": "ID8fac",
              "device": "/dev/ttyM1",
              "mode": 3,
              "time": "2020-08-24T07:01:31.000Z",
              "ept": 0.005,
              "lat": -37.043028622,
              "lon": 145.984996786,
              "alt": 708.492,
              "epx": 9.963,
              "epy": 14.642,
              "epv": 0,
              "speed": 0,
              "climb": 0,
              "eps": 29.28
            }
          ],
          "gst": [
            {
              "class": "GST",
              "tag": "ID8fac",
              "device": "/dev/ttyM1",
              "time": "1970-01-01T00:00:00.000Z",
              "rms": 0,
              "major": 0,
              "minor": 0,
              "orient": 0,
              "lat": 0,
              "lon": 0,
              "alt": 0
            }
          ],
          "sky": [
            {
              "class": "SKY",
              "tag": "ID8fac",
              "device": "/dev/ttyM1",
              "xdop": 0.66,
              "ydop": 0.98,
              "vdop": 0,
              "tdop": 1,
              "hdop": 0,
              "gdop": 1,
              "pdop": 0,
              "satellites": [
                {
                  "PRN": 17,
                  "el": 42,
                  "az": 137,
                  "ss": 43,
                  "used": true
                },
                {
                  "PRN": 12,
                  "el": 27,
                  "az": 241,
                  "ss": 44,
                  "used": true
                },
                {
                  "PRN": 24,
                  "el": 53,
                  "az": 247,
                  "ss": 46,
                  "used": true
                },
                {
                  "PRN": 6,
                  "el": 55,
                  "az": 54,
                  "ss": 36,
                  "used": true
                },
                {
                  "PRN": 15,
                  "el": 10,
                  "az": 307,
                  "ss": 40,
                  "used": true
                },
                {
                  "PRN": 2,
                  "el": 31,
                  "az": 358,
                  "ss": 37,
                  "used": true
                },
                {
                  "PRN": 28,
                  "el": 20,
                  "az": 89,
                  "ss": 35,
                  "used": true
                },
                {
                  "PRN": 7,
                  "el": 10,
                  "az": 52,
                  "ss": 31,
                  "used": false
                },
                {
                  "PRN": 19,
                  "el": 64,
                  "az": 148,
                  "ss": 45,
                  "used": true
                },
                {
                  "PRN": 13,
                  "el": 10,
                  "az": 338,
                  "ss": 29,
                  "used": false
                },
                {
                  "PRN": 15,
                  "el": 18,
                  "az": 297,
                  "ss": 33,
                  "used": true
                },
                {
                  "PRN": 22,
                  "el": 10,
                  "az": 17,
                  "ss": 39,
                  "used": false
                }
              ]
            }
          ]
        },
        "output": "9 12"
      }
    ],
    "identifier": 63556425
  },
  {
    "context": [
      "I am wondering if there is a way to always have my terminal(s) output JSON data nicely formatted without having to append the ```| jq .``` command to the end of it?",
      "You could start with a simple script, e.g.\n```bash\n$ cat curljq\n#!/bin/bash\ncurl \"$@\" | jq .\n```\n```bash\n$ chmod +x curljq\n$ ./curljq -Ss -H \"Accept: application/json\" https://reqbin.com/echo/get/json\n{\n  \"success\": \"true\"\n}\n```"
    ],
    "utterance": "View output from curl requests always nicely formatted by piping it through jq, without manually appending jq to each command.",
    "expressions": [
      "curl \"$@\" | jq ."
    ],
    "identifier": 63641481
  },
  {
    "context": [
      "I would like to iterate through the keys and transform JSON into Prometheus metric format.",
      "aws_cost{env=\"env1\",aws_service=\"KMS\",product=\"product1\",backend=\"backend1\",subservice=\"subservice1\"} 0.21",
      "$ jq --stream -r '\nselect(length == 2) as [[$backend, $product, $subservice, $env, $aws_service], $value]\n  | {$env, $aws_service, $product, $backend, $subservice}\n  | \"aws_cost{\\([to_entries[] | \"\\(.key)=\\(.value|tojson)\"] | join(\",\"))} \\($value)\"\n' input.json",
      ". as $data |\npaths(scalars) | . as $path |\n\"aws_cost{env=\\\"\\($path[3])\\\",aws_service=\\\"\\($path[4])\\\",product=\\\"\\($path[1])\\\",backend=\\\"\\($path[0])\\\",subservice=\\\"\\($path[2])\\\"} \\($data | getpath($path))\"",
      "to_entries[] | .key as $backend | .value |\nto_entries[] | .key as $product | .value |\nto_entries[] | .key as $subservice | .value |\nto_entries[] | .key as $env | .value |\nto_entries[] | .key as $service | \n\"aws_cost{env=\\\"\\($env)\\\",aws_service\\\"\\($service)\\\",product=\\\"\\($product)\\\",backend=\\\"\\($backend)\\\",subservice=\\\"\\($subservice)\\\"} \\(.value)\""
    ],
    "utterance": "Transform deeply nested data with variable key names into flat metric strings in Prometheus format including env, aws_service, product, backend, subservice, and the value.",
    "expressions": [
      "--stream -r '\nselect(length == 2) as [[$backend, $product, $subservice, $env, $aws_service], $value]\n  | {$env, $aws_service, $product, $backend, $subservice}\n  | \"aws_cost{\\([to_entries[] | \"\\(.key)=\\(.value|tojson)\"] | join(\",\"))} \\($value)\"'",
      ". as $data |\npaths(scalars) | . as $path |\n\"aws_cost{env=\\\"\\($path[3])\\\",aws_service=\\\"\\($path[4])\\\",product=\\\"\\($path[1])\\\",backend=\\\"\\($path[0])\\\",subservice=\\\"\\($path[2])\\\"} \\($data | getpath($path))\"",
      "to_entries[] | .key as $backend | .value |\nto_entries[] | .key as $product | .value |\nto_entries[] | .key as $subservice | .value |\nto_entries[] | .key as $env | .value |\nto_entries[] | .key as $service |\n\"aws_cost{env=\\\"\\($env)\\\",aws_service=\\\"\\($service)\\\",product=\\\"\\($product)\\\",backend=\\\"\\($backend)\\\",subservice=\\\"\\($subservice)\\\"} \\(.value)\""
    ],
    "data": [
      {
        "input": {
          "backend1": {
            "product1": {
              "subservice1": {
                "env1": {
                  "KMS": "0.21",
                  "DynamoDB": "235.91",
                  "ElastiCache": "108.85",
                  "Elastic Load Balancing": "324.29"
                },
                "env2": {
                  "KMS": "0.21",
                  "Elastic Load Balancing": "3.78"
                }
              }
            }
          },
          "backend2": {
            "product2": {
              "subservice2": {
                "env1": {
                  "KMS": "0.21",
                  "ElastiCache": "108.85",
                  "Elastic Load Balancing": "41.18"
                },
                "env2": {
                  "KMS": "0.21",
                  "Elastic Load Balancing": "3.78"
                }
              }
            }
          }
        },
        "output": [
          "aws_cost{env=\"env1\",aws_service=\"KMS\",product=\"product1\",backend=\"backend1\",subservice=\"subservice1\"} 0.21",
          "aws_cost{env=\"env1\",aws_service=\"DynamoDB\",product=\"product1\",backend=\"backend1\",subservice=\"subservice1\"} 235.91",
          "aws_cost{env=\"env1\",aws_service=\"ElastiCache\",product=\"product1\",backend=\"backend1\",subservice=\"subservice1\"} 108.85",
          "aws_cost{env=\"env1\",aws_service=\"Elastic Load Balancing\",product=\"product1\",backend=\"backend1\",subservice=\"subservice1\"} 324.29",
          "aws_cost{env=\"env2\",aws_service=\"KMS\",product=\"product1\",backend=\"backend1\",subservice=\"subservice1\"} 0.21",
          "aws_cost{env=\"env2\",aws_service=\"Elastic Load Balancing\",product=\"product1\",backend=\"backend1\",subservice=\"subservice1\"} 3.78",
          "aws_cost{env=\"env1\",aws_service=\"KMS\",product=\"product2\",backend=\"backend2\",subservice=\"subservice2\"} 0.21",
          "aws_cost{env=\"env1\",aws_service=\"ElastiCache\",product=\"product2\",backend=\"backend2\",subservice=\"subservice2\"} 108.85",
          "aws_cost{env=\"env1\",aws_service=\"Elastic Load Balancing\",product=\"product2\",backend=\"backend2\",subservice=\"subservice2\"} 41.18",
          "aws_cost{env=\"env2\",aws_service=\"KMS\",product=\"product2\",backend=\"backend2\",subservice=\"subservice2\"} 0.21",
          "aws_cost{env=\"env2\",aws_service=\"Elastic Load Balancing\",product=\"product2\",backend=\"backend2\",subservice=\"subservice2\"} 3.78"
        ]
      }
    ],
    "identifier": 63516078
  },
  {
    "context": [
      "Or you could output a more structured object from the jq query: `.Reservations[].Instances[]|{InstanceId,SecurityGroups}`",
      "I don't have access to AWS to check but that should get you one object for each instance with only two fields - the InstanceId and the array of SecurityGroups.",
      "Lastly if you want to output one object per security group but still label them with InstanceId you can do: `.Reservations[].Instances[]|{InstanceId,SecurityGroup:.SecurityGroups[]}`"
    ],
    "utterance": "Show for each instance its InstanceId together with its full list of security groups.",
    "expressions": [
      ".Reservations[].Instances[] | {InstanceId, SecurityGroups}"
    ],
    "data": [
      {
        "input": {
          "Reservations": [
            {
              "Instances": [
                {
                  "InstanceId": "i-0b0bcbf0b766504ea",
                  "ImageId": "ami-0d093cc932863f7a9",
                  "SecurityGroups": [
                    {
                      "GroupName": "usw2-staging-zookeeper-serv",
                      "GroupId": "sg-da9361a1"
                    }
                  ]
                },
                {
                  "InstanceId": "i-0123456789abcdef0",
                  "SecurityGroups": [
                    {
                      "GroupName": "prod-web",
                      "GroupId": "sg-abcd1234"
                    },
                    {
                      "GroupName": "shared-ssh",
                      "GroupId": "sg-55667788"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          {
            "InstanceId": "i-0b0bcbf0b766504ea",
            "SecurityGroups": [
              {
                "GroupName": "usw2-staging-zookeeper-serv",
                "GroupId": "sg-da9361a1"
              }
            ]
          },
          {
            "InstanceId": "i-0123456789abcdef0",
            "SecurityGroups": [
              {
                "GroupName": "prod-web",
                "GroupId": "sg-abcd1234"
              },
              {
                "GroupName": "shared-ssh",
                "GroupId": "sg-55667788"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 63642265
  },
  {
    "context": [
      "I have the following JSON:",
      "But I want to return:",
      "I also need to remove the port number and colon. Is that possible?",
      "You can do below, to select values that are not _empty_ using `with_entries(expr)`, with the _expr_ being the condition that excludes the empty fields.",
      "Also use the `.value` field again to remove the string that matches the regex containing the port string.",
      "jq '.data |= map(with_entries(select(.value != \"\") | .value |= sub(\":[0-9][0-9]$\"; \"\")))'"
    ],
    "utterance": "For each object in the data array, remove any key whose value is an empty string and, for the {#IP} key, also remove the colon and two-digit port number from the value if present.",
    "expressions": [
      ".data |= map(with_entries(select(.value != \"\") | .value |= sub(\":[0-9][0-9]$\"; \"\")))"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "{#NAME}": "Test 1",
              "{#ID}": "1",
              "{#IP}": "192.168.1.2:80"
            },
            {
              "{#NAME}": "Test 2",
              "{#ID}": "2",
              "{#IP}": ""
            },
            {
              "{#NAME}": "Test 3",
              "{#ID}": "3",
              "{#IP}": "192.168.1.3:80"
            },
            {
              "{#NAME}": "Test 4",
              "{#ID}": "4",
              "{#IP}": "192.168.1.4:80"
            },
            {
              "{#NAME}": "Test 5",
              "{#ID}": "5",
              "{#IP}": ""
            }
          ]
        },
        "output": {
          "data": [
            {
              "{#NAME}": "Test 1",
              "{#ID}": "1",
              "{#IP}": "192.168.1.2"
            },
            {
              "{#NAME}": "Test 2",
              "{#ID}": "2"
            },
            {
              "{#NAME}": "Test 3",
              "{#ID}": "3",
              "{#IP}": "192.168.1.3"
            },
            {
              "{#NAME}": "Test 4",
              "{#ID}": "4",
              "{#IP}": "192.168.1.4"
            },
            {
              "{#NAME}": "Test 5",
              "{#ID}": "5"
            }
          ]
        }
      }
    ],
    "identifier": 63635682
  },
  {
    "context": [
      "a command gives the following output which is arranged in an object, how to convert it to json using jq?",
      "the output isn't json; it contains `\\n` strings.",
      "If the issue here is that the quasi-JSON contains literal \"\\n\" strings, then you could perhaps remove them using `sed 's/\\\\n//g'`:",
      "$ jq -n -f <(sed 's/\\\\n//g' <<< \"$output\")"
    ],
    "utterance": "Convert an object-like string with literal \\n sequences (e.g., \"{\\n  currentBlock: 4769045,\\n  highestBlock: ... }\") into a valid data structure and extract it as structured data after removing the \\n strings.",
    "expressions": [
      "jq -n -f <(sed 's/\\\\n//g' <<< \"$output\")"
    ],
    "data": [
      {
        "input": "{\\n  currentBlock: 4769045,\\n  highestBlock: 7063981,\\n  knownStates: 15306625,\\n  pulledStates: 15306625,\\n  startingBlock: 0\\n}",
        "output": {
          "currentBlock": 4769045,
          "highestBlock": 7063981,
          "knownStates": 15306625,
          "pulledStates": 15306625,
          "startingBlock": 0
        }
      }
    ],
    "identifier": 63653321
  },
  {
    "context": [
      "I would like a way to automatically loop through the large file... and only use 10000 lines as a time as $FILE... up until the end of the list.",
      "Here&#39;s a simple and efficient solution that at its core just uses jq.  It takes advantage of the -c command-line option.",
      "< data.txt jq -Rnc '\n  def batch($n; stream):\n    def b: [limit($n; stream)]\n    | select(length > 0)\n    | (., b);\n    b;\n\n  {id: batch(10000; inputs | select(length>0) | (. / \";\")[0])}\n' | xargs printf \"%s\\n\"\n",
      "Parameterizing batch size: It might make sense to set things up so that the batch size is specified outside the jq program.  This could be done in numerous ways, e.g. by invoking jq along the lines of:\n\n    jq --argjson n 10000 ....\n\nand of course using $n instead of 10000 in the jq program."
    ],
    "utterance": "Batch lines from a file into groups of 10000, wrapping each group as the array value of an 'id' key, and emit one object per group.",
    "expressions": [
      "jq -Rnc '\ndef batch($n; stream):\n  def b: [limit($n; stream)]\n  | select(length > 0)\n  | (., b);\n  b;\n\n{id: batch(10000; inputs | select(length>0) | (. / \";\")[0])}\n'"
    ],
    "data": [
      {
        "input": "wef7efwe1fwe8\nwef7efwe1fwe3\newefwefwfwgrwergrgr\n",
        "output": [
          {
            "id": [
              "wef7efwe1fwe8",
              "wef7efwe1fwe3",
              "ewefwefwfwgrwergrgr"
            ]
          }
        ]
      }
    ],
    "identifier": 63649672
  },
  {
    "context": [
      "The purpose of this script is to go thru the ``CronJobName CronJobResult`` and other parameters defined in the ``check_config_list`` to identify all these Tenants which are missing one or more such parameters.",
      "jq -r --arg search_param \"$i\" '[.[] | select ( .Body.values)] | [.[] | select (all(.Body.values[]; .name != $search_param ) )] | .[].Header.Tenant' \"$dc1\"",
      "jq -r '(\"CronJobName\", \"CronJobResult\") as $search_param\n  | [.[] | select( .Body.values)]\n  | [.[] | select (all(.Body.values[]; .name != $search_param ) )]\n  | .[].Header.Tenant' \"$dc1\"",
      "jq -r --argjson search_params '[\"CronJobName\", \"CronJobResult\"]' ' $search_params[] as $search_param\n  | [.[] | select ( .Body.values)]\n  | [.[] | select (all(.Body.values[]; .name != $search_param ) )]\n  | .[].Header.Tenant' \"$dc1\""
    ],
    "utterance": "List all Tenant values where any of the parameters CronJobName or CronJobResult are missing from the Body.values[].name array.",
    "expressions": [
      "[.[] | select( .Body.values )] | [.[] | select (all(.Body.values[]; .name != $search_param ))] | .[].Header.Tenant",
      "(\"CronJobName\", \"CronJobResult\") as $search_param | [.[] | select( .Body.values)] | [.[] | select (all(.Body.values[]; .name != $search_param ) )] | .[].Header.Tenant",
      "--argjson search_params '[\"CronJobName\", \"CronJobResult\"]' '$search_params[] as $search_param | [.[] | select ( .Body.values)] | [.[] | select (all(.Body.values[]; .name != $search_param ) )] | .[].Header.Tenant'"
    ],
    "data": [
      {
        "input": [
          {
            "Header": {
              "Tenant": "mytenant"
            },
            "Body": {
              "values": [
                {
                  "id": "aaaa0001-0a0a-0b0b-0c0c-07a3a4decaa6",
                  "name": "Currency"
                },
                {
                  "id": "aaaa0001-0a0a-0b0b-0c0c-9390805c3b09",
                  "name": "CronJobName"
                }
              ]
            }
          }
        ],
        "output": [
          "mytenant"
        ]
      }
    ],
    "identifier": 63644576
  },
  {
    "context": [
      "I was wondering if someone had an idea how to extract with 'jq' the following strings; 'ip, port' from the input files available on Rapid7 opendata website:",
      "$ zcat 2020-07-26-1595771130-https_get_50880.json.gz | jq '.ip,.port' | head",
      "zcat 2020-07-26-1595771130-https_get_50880.json.gz | jq -r '\"\\(.ip):\\(.port)\"' | head"
    ],
    "utterance": "Extract ip and port fields as ip:port strings from each record in the input data.",
    "expressions": [
      "\"\\(.ip):\\(.port)\"",
      "-r \"\\(.ip):\\(.port)\""
    ],
    "data": [
      {
        "input": [
          {
            "ip": "73.71.198.224",
            "port": 50880,
            "tls": {
              "cipher": "TLS_ECDHE_RSA..."
            }
          },
          {
            "ip": "3.228.14.207",
            "port": 50880,
            "tls": {
              "cipher": "TLS_RSA..."
            }
          }
        ],
        "output": [
          "73.71.198.224:50880",
          "3.228.14.207:50880"
        ]
      }
    ],
    "identifier": 63662634
  },
  {
    "context": [
      ".tasks[]|.taskArn,.createdAt,.taskDefinitionArn",
      "How can I convert the epoch time into a date within the same command?",
      "Use `todateiso8601` to convert the epoch time to an iso date string.",
      "... | jq -r '.tasks[] | .taskArn, (.createdAt | todateiso8601), .taskDefinitionArn'"
    ],
    "utterance": "Display each task's taskArn, createdAt as an ISO 8601 date, and taskDefinitionArn.",
    "expressions": [
      ".tasks[] | .taskArn, (.createdAt | todateiso8601), .taskDefinitionArn"
    ],
    "data": [
      {
        "input": {
          "tasks": [
            {
              "taskArn": "arn:aws:ecs:eu-west-1:871479025269:task/ABC/1a9a276e0a044d3d337ff954cfa6b1f36bc66",
              "createdAt": 1595602422.013,
              "taskDefinitionArn": "arn:aws:ecs:eu-west-1:87147922025269:task-definition/new:1"
            }
          ]
        },
        "output": [
          "arn:aws:ecs:eu-west-1:871479025269:task/ABC/1a9a276e0a044d3d337ff954cfa6b1f36bc66",
          "2020-07-24T14:53:42Z",
          "arn:aws:ecs:eu-west-1:87147922025269:task-definition/new:1"
        ]
      }
    ],
    "identifier": 63671299
  },
  {
    "context": [
      "Desired output:\n\n```\nTest-d1, dev, b2b, Unsupported authorization scheme, 401\n2734d7ac0f0e, unknown, unknown, Not found, 404\n```",
      "So skip the keys, interested only with certain values and form a single line, separate them by commas or semicolumn or some other separator.",
      "jq  -r .[] | [ .Header.Tenant, .Header.Stage, .Header.ProductType, .Body.error.message, .Body.error.code ] | @csv",
      "if you want strings to be presented unconditionally without the surrounding quotation marks, you could consider using `join(\", \")` instead of `@csv`.",
      "you might also wish to consider `@tsv`.",
      ".[] \n| (.Header     | [.Tenant, .Stage, .ProductType]) + \n  (.Body.error | [.message, .code ])\n| @tsv"
    ],
    "utterance": "Output values from each object: Header.Tenant, Header.Stage, Header.ProductType, Body.error.message, Body.error.code, joined in a single line separated by a comma, semicolon, or tab, with no extra quotes.",
    "expressions": [
      ".[] | [ .Header.Tenant, .Header.Stage, .Header.ProductType, .Body.error.message, .Body.error.code ] | join(\", \")",
      ".[] | [ .Header.Tenant, .Header.Stage, .Header.ProductType, .Body.error.message, .Body.error.code ] | join(\"\t\")",
      ".[] | (.Header | [.Tenant, .Stage, .ProductType]) + (.Body.error | [.message, .code ]) | @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "Header": {
              "Tenant": "Test-d1",
              "Stage": "dev",
              "ProductType": "b2b",
              "Rcode": 401
            },
            "Body": {
              "error": {
                "code": 401,
                "message": "Unsupported authorization scheme"
              }
            }
          },
          {
            "Header": {
              "Tenant": "2734d7ac0f0e",
              "Stage": "unknown",
              "ProductType": "unknown",
              "Rcode": 404
            },
            "Body": {
              "error": {
                "code": 404,
                "message": "Not found"
              }
            }
          }
        ],
        "output": [
          "Test-d1, dev, b2b, Unsupported authorization scheme, 401",
          "2734d7ac0f0e, unknown, unknown, Not found, 404"
        ]
      }
    ],
    "identifier": 63653577
  },
  {
    "context": [
      "The value I want to have in this object is the value for attribute named attr1. How I can achieve this with jq?",
      "map({ username,\r\n           value: first(.attributes[]\r\n                        | select(.name == \"attr1\")\r\n                        | .value) })"
    ],
    "utterance": "For each user, extract their username and the value where the attribute name is attr1.",
    "expressions": [
      "map({ username, value: first(.attributes[] | select(.name == \"attr1\") | .value) })"
    ],
    "data": [
      {
        "input": [
          {
            "username": "new",
            "attributes": [
              {
                "name": "attr1",
                "value": "value1"
              },
              {
                "name": "attr2",
                "value": "value2"
              }
            ]
          },
          {
            "username": "new2",
            "attributes": [
              {
                "name": "attr2",
                "value": "value3"
              },
              {
                "name": "attr1",
                "value": "value4"
              }
            ]
          }
        ],
        "output": [
          {
            "username": "new",
            "value": "value1"
          },
          {
            "username": "new2",
            "value": "value4"
          }
        ]
      }
    ],
    "identifier": 63666491
  },
  {
    "context": [
      "I want to extract a domain list that has the state \"Active\".",
      "jq: error (at test.json:1): Cannot iterate over string (\"[{\\\"domain...)",
      "As @Inian pointed out, the key here is to use `fromjson`.  Putting it all together:",
      "jq -r 'fromjson[] | select(.state==\"Active\") | .domain'"
    ],
    "utterance": "Extract the domain values from array elements where state equals \"Active\" when the input is a stringified array.",
    "expressions": [
      "fromjson[] | select(.state == \"Active\") | .domain",
      "-r 'fromjson[] | select(.state==\"Active\") | .domain'"
    ],
    "data": [
      {
        "input": "[{\"domain\": \"domain.com\", \"adminEmail\": \"test@example.com\", \"ipAddress\": \"1.1.1.1\", \"admin\": \"admin\", \"package\": \"Default\", \"state\": \"Active\"},{\"domain\": \"domain2.com\", \"adminEmail\": \"test@example.com\", \"ipAddress\": \"8.8.8.8\", \"admin\": \"admin2\", \"package\": \"Default\", \"state\": \"Active\"},{\"domain\": \"domain3.com\", \"adminEmail\": \"test@domain3.com\", \"ipAddress\": \"8.8.4.4\", \"admin\": \"admin3\", \"package\": \"Default\", \"state\": \"Active\"}]",
        "output": [
          "domain.com",
          "domain2.com",
          "domain3.com"
        ]
      }
    ],
    "identifier": 63682351
  },
  {
    "context": [
      "Such command works successfully:\r\n\r\n    jq '.values[].data | .items[]' my.json",
      "And simple attempt to save variable leads to fail:\r\n\r\n    jq '.values[].data as $p | .items[]' my.json",
      "Instead of\r\n\r\n    .values[].data as $p\r\n\nyou would have to write:\r\n\r\n    .values[].data | . as $p"
    ],
    "utterance": "Iterate over items inside the data field of each object within values, while assigning data to a temporary variable.",
    "expressions": [
      ".values[].data | . as $p | .items[]"
    ],
    "identifier": 63705330
  },
  {
    "context": [
      "I have a large json array of objects. Each object contains a `foreignKeyId`, a `url`, (optionally) a `urlMirror1`, and (optionally) a `urlMirror2`.",
      "I want to normalize this json to something like below:",
      "{ \"foreignKeyId\": 1, \"primariness\": 1, \"url\": \"https://1-url.com\" },\n...\n{ \"foreignKeyId\": 3, \"primariness\": 3, \"url\": \"https://3-url-mirror-2.com\" }",
      "`primariness` should be derived from the key names (`url` => `1`, `urlMirror1` => `2`, `urlMirror2` => `3`. Order of the keys inside any given object is insignificant. There is a fixed number of mirrors (e.g., there is never a `urlMirror3`).",
      "Here is a simple script with hardcoded number of mirrors and primariness.",
      "map(\n    { foreinKeyId } +\n    (\n        { primariness: 1, url },\n        (.urlMirror1 // empty | { primariness: 2, url: . }),\n        (.urlMirror2 // empty | { primariness: 3, url: . })\n    )\n)",
      "Here's a general solution, that is, it will handle arbitrarily many urlMirrors.",
      "def primarinesses:\n  {foreinKeyId} +\n    ({primariness:1, url},\n     (to_entries[]\n      | (.key | capture( \"^urlMirror(?<n>[0-9]+)\")) as $n\n      | {primariness: ($n.n | tonumber + 1), url : .value } )) ;",
      "[.[] | primarinesses]",
      "map(primarinesses)"
    ],
    "utterance": "Expand each object with foreignKeyId, url, and optional urlMirror fields into multiple objects, each containing foreignKeyId, primariness (1 for url, 2 for urlMirror1, 3 for urlMirror2), and url, omitting absent fields.",
    "expressions": [
      "map({ foreignKeyId } + ({ primariness: 1, url }, (.urlMirror1 // empty | { primariness: 2, url: . }), (.urlMirror2 // empty | { primariness: 3, url: . })))",
      "def primarinesses: {foreignKeyId} + ({primariness:1, url}, (to_entries[] | (.key | capture(\"^urlMirror(?<n>[0-9]+)\")) as $n | {primariness: ($n.n | tonumber + 1), url : .value })); map(primarinesses)"
    ],
    "data": [
      {
        "input": [
          {
            "foreignKeyId": 1,
            "url": "https://1-url.com"
          },
          {
            "foreignKeyId": 2,
            "url": "https://2-url.com",
            "urlMirror1": "https://2-url-mirror-1.com"
          },
          {
            "foreignKeyId": 3,
            "url": "https://3-url.com",
            "urlMirror1": "https://3-url-mirror-1.com",
            "urlMirror2": "https://3-url-mirror-2.com"
          }
        ],
        "output": [
          {
            "foreignKeyId": 1,
            "primariness": 1,
            "url": "https://1-url.com"
          },
          {
            "foreignKeyId": 2,
            "primariness": 1,
            "url": "https://2-url.com"
          },
          {
            "foreignKeyId": 2,
            "primariness": 2,
            "url": "https://2-url-mirror-1.com"
          },
          {
            "foreignKeyId": 3,
            "primariness": 1,
            "url": "https://3-url.com"
          },
          {
            "foreignKeyId": 3,
            "primariness": 2,
            "url": "https://3-url-mirror-1.com"
          },
          {
            "foreignKeyId": 3,
            "primariness": 3,
            "url": "https://3-url-mirror-2.com"
          }
        ]
      }
    ],
    "identifier": 63616669
  },
  {
    "context": [
      "I am trying to select a sub-set of an object's children in `jq` while keeping the outer object.",
      "But I suspect there is a more succinct way to filter the innards of a nested array, perhaps removing the duplication.",
      "jq '. + {changes: [.changes[] | select(.status != \"untracked\")]}''",
      ".changes |= map(select(.status != \"untracked\"))"
    ],
    "utterance": "Filter the 'changes' array to exclude elements where status is 'untracked', while keeping the rest of the object unchanged.",
    "expressions": [
      ".changes |= map(select(.status != \"untracked\"))",
      ". + {changes: [.changes[] | select(.status != \"untracked\")]}"
    ],
    "data": [
      {
        "input": {
          "head": "master",
          "hash": "ba2054c38ec68b73926acb24cd0bad61177a03d4",
          "upstream": "origin/master",
          "ahead": 1,
          "behind": 0,
          "changes": [
            {
              "name": "exe/each-package",
              "status": "updated_in_index",
              "work_tree_status": "modified",
              "index_status": "unmodified"
            },
            {
              "name": "exe/find-package",
              "status": "not_updated",
              "work_tree_status": "unmodified",
              "index_status": "modified"
            },
            {
              "name": "lib/tools/tool_support.rb",
              "status": "not_updated",
              "work_tree_status": "unmodified",
              "index_status": "modified"
            },
            {
              "name": "curses.txt",
              "status": "untracked",
              "work_tree_status": "untracked",
              "index_status": "untracked"
            },
            {
              "name": "exe/fat-stat",
              "status": "untracked",
              "work_tree_status": "untracked",
              "index_status": "untracked"
            },
            {
              "name": "exe/prefix-each-with",
              "status": "untracked",
              "work_tree_status": "untracked",
              "index_status": "untracked"
            },
            {
              "name": "notes.txt",
              "status": "untracked",
              "work_tree_status": "untracked",
              "index_status": "untracked"
            }
          ]
        },
        "output": {
          "head": "master",
          "hash": "ba2054c38ec68b73926acb24cd0bad61177a03d4",
          "upstream": "origin/master",
          "ahead": 1,
          "behind": 0,
          "changes": [
            {
              "name": "exe/each-package",
              "status": "updated_in_index",
              "work_tree_status": "modified",
              "index_status": "unmodified"
            },
            {
              "name": "exe/find-package",
              "status": "not_updated",
              "work_tree_status": "unmodified",
              "index_status": "modified"
            },
            {
              "name": "lib/tools/tool_support.rb",
              "status": "not_updated",
              "work_tree_status": "unmodified",
              "index_status": "modified"
            }
          ]
        }
      }
    ],
    "identifier": 63678557
  },
  {
    "context": [
      "and if id == \"f3ea5f20-e773-11ea-8cae-c1046c8b1215\" or id == \"5c071f30-e797-11ea-8cae-c1046c8b1215\" I want to remove this keys, so output should be:",
      "You were close.",
      "jq '.saved_objects=(\n            .saved_objects[] |\n                select (.id != \"f3ea5f20-e773-11ea-8cae-c1046c8b1215\"\n                        and .id != \"5c071f30-e797-11ea-8cae-c1046c8b1215\"))\n        ' file.json",
      "[\"f3ea5f20-e773-11ea-8cae-c1046c8b1215\", \"5c071f30-e797-11ea-8cae-c1046c8b1215\"] as $blacklist\n| .saved_objects |= map(select(.id | IN($blacklist[]) | not))",
      "[\"f3ea5f20-e773-11ea-8cae-c1046c8b1215\", \"5c071f30-e797-11ea-8cae-c1046c8b1215\"] as $blacklist\n| del(.saved_objects[] | select(.id | IN($blacklist[])))"
    ],
    "utterance": "Remove objects from the saved_objects array whose id is either \"f3ea5f20-e773-11ea-8cae-c1046c8b1215\" or \"5c071f30-e797-11ea-8cae-c1046c8b1215\".",
    "expressions": [
      ".saved_objects=(.saved_objects[] | select(.id != \"f3ea5f20-e773-11ea-8cae-c1046c8b1215\" and .id != \"5c071f30-e797-11ea-8cae-c1046c8b1215\"))",
      "[\"f3ea5f20-e773-11ea-8cae-c1046c8b1215\", \"5c071f30-e797-11ea-8cae-c1046c8b1215\"] as $blacklist | .saved_objects |= map(select(.id | IN($blacklist[]) | not))",
      "[\"f3ea5f20-e773-11ea-8cae-c1046c8b1215\", \"5c071f30-e797-11ea-8cae-c1046c8b1215\"] as $blacklist | del(.saved_objects[] | select(.id | IN($blacklist[])))"
    ],
    "data": [
      {
        "input": {
          "page": 1,
          "per_page": 20,
          "total": 3,
          "saved_objects": [
            {
              "type": "dashboard",
              "id": "f3ea5f20-e773-11ea-8cae-c1046c8b1215"
            },
            {
              "type": "dashboard",
              "id": "5c071f30-e797-11ea-8cae-c1046c8b1215"
            },
            {
              "type": "dashboard",
              "id": "644a15c0-e79d-11ea-8cae-c1046c8b1215"
            }
          ]
        },
        "output": {
          "page": 1,
          "per_page": 20,
          "total": 3,
          "saved_objects": [
            {
              "type": "dashboard",
              "id": "644a15c0-e79d-11ea-8cae-c1046c8b1215"
            }
          ]
        }
      }
    ],
    "identifier": 63672380
  },
  {
    "context": [
      "This does not work for `json_string={\"fruit\":{\"name\":\"app`. this still shows **Parsed JSON successfully and got something other than false/null** where as the json string is incomplete.",
      "jq -e . <<< '{\"fruit\":{\"name\":\"app'",
      "parse error: Unfinished string at EOF at line 2, column 0",
      "echo $?",
      "4"
    ],
    "utterance": "Verify that an input string is syntactically valid and complete by checking for parse errors in unterminated or malformed structures.",
    "expressions": [
      "jq -e . <<< \"$json_string\""
    ],
    "data": [
      {
        "input": "{\"fruit\":{\"name\":\"app",
        "output": null
      }
    ],
    "identifier": 63739082
  },
  {
    "context": [
      "I\u2019d like to take timestamp from the \"data\" in the first array, and join it with the maximum value from the first and the second array, like this:\n\"2020-09-01T00:30:00+00:00\", 100, 69\n\"2020-09-02T00:30:00+00:00\", 93, 72\n\"2020-09-03T00:30:00+00:00\", 97, 71",
      "Using `transpose` makes for a compact solution:\n```\n[.[] | .data]\n| transpose[]\n| [.[0].timeStamp, (.[]|.maximum)]\n| @csv\n```",
      "With the given input, the output, however, would be:\n\"2020-09-01T00:30:00+00:00\",100,69\n\"2020-09-02T00:30:00+00:00\",100,72\n\"2020-09-03T00:30:00+00:00\",97,71"
    ],
    "utterance": "For each entry at the same index in two objects' data arrays, output the timestamp from the first object's entry and the maximum fields from both objects' entries as a CSV row.",
    "expressions": [
      "[.[] | .data] | transpose[] | [.[0].timeStamp, (.[]|.maximum)] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "data": [
              {
                "average": null,
                "count": null,
                "maximum": 100.0,
                "minimum": null,
                "timeStamp": "2020-09-01T00:30:00+00:00",
                "total": null
              },
              {
                "average": null,
                "count": null,
                "maximum": 100.0,
                "minimum": null,
                "timeStamp": "2020-09-02T00:30:00+00:00",
                "total": null
              },
              {
                "average": null,
                "count": null,
                "maximum": 97.0,
                "minimum": null,
                "timeStamp": "2020-09-03T00:30:00+00:00",
                "total": null
              }
            ],
            "metadatavalues": []
          },
          {
            "data": [
              {
                "average": null,
                "count": null,
                "maximum": 69.0,
                "minimum": null,
                "timeStamp": "2020-09-01T00:30:00+00:00",
                "total": null
              },
              {
                "average": null,
                "count": null,
                "maximum": 72.0,
                "minimum": null,
                "timeStamp": "2020-09-02T00:30:00+00:00",
                "total": null
              },
              {
                "average": null,
                "count": null,
                "maximum": 71.0,
                "minimum": null,
                "timeStamp": "2020-09-03T00:30:00+00:00",
                "total": null
              }
            ],
            "metadatavalues": []
          }
        ],
        "output": [
          "\"2020-09-01T00:30:00+00:00\",100,69",
          "\"2020-09-02T00:30:00+00:00\",100,72",
          "\"2020-09-03T00:30:00+00:00\",97,71"
        ]
      }
    ],
    "identifier": 63731489
  },
  {
    "context": [
      "I\u2019m trying to extract coordinates of nodes with the <tag k=\"power\"> tags.",
      "You need to be able to distinguish between them in your filter while extracting. Also filter out objects that don\u2019t have the .tag property at all",
      "One simple way to solve it would be to use an explicit if statement to do the comparison",
      "xq '\n.osm.node[] | \nselect(.tag != null) | \nif (.tag|type == \"array\") then \n  select(any(.tag[]; .[\"@k\"] == \"power\")) \nelse \n  select(any(.tag; .[\"@k\"] == \"power\")) \nend\n' power.xml",
      "or make the conditional branch as a function",
      "xq '\ndef nodeSel($p): if ($p|type == \"array\") then select(any($p[]; .[\"@k\"] == \"power\")) else select(any($p; .[\"@k\"] == \"power\")) end;\n.osm.node[] | \nselect(.tag != null) |\nnodeSel(.tag)\n' power.xml"
    ],
    "utterance": "Select all node elements that have at least one tag with k equal to \"power\", handling both cases where tag is an array or an object.",
    "expressions": [
      ".osm.node[] | select(.tag != null) | if (.tag|type == \"array\") then select(any(.tag[]; .[\"@k\"] == \"power\")) else select(any(.tag; .[\"@k\"] == \"power\")) end",
      "def nodeSel($p): if ($p|type == \"array\") then select(any($p[]; .[\"@k\"] == \"power\")) else select(any($p; .[\"@k\"] == \"power\")) end; .osm.node[] | select(.tag != null) | nodeSel(.tag)"
    ],
    "identifier": 63703049
  },
  {
    "context": [
      "I would like to have an output of key and value of items->images->names if one of its keys is \"n2_agent_centos\".",
      "d50d-hlx-app13:3601/n2_agent_centos:11.0.2.1",
      ".items[].status.images[].names[]\n| select(test(\"/n2_agent_centos:\"))"
    ],
    "utterance": "Return all values from the items[].status.images[].names array that include '/n2_agent_centos:'.",
    "expressions": [
      ".items[].status.images[].names[] | select(test(\"/n2_agent_centos:\"))"
    ],
    "data": [
      {
        "input": {
          "kind": "NodeList",
          "apiVersion": "v1",
          "metadata": {
            "selfLink": "/api/v1/nodes",
            "resourceVersion": "6666628"
          },
          "items": [
            {
              "status": {
                "images": [
                  {
                    "names": [
                      "d50d-hlx-app13:3601/n2_agent_centos@sha256:319fea95daa46243c48ad9df4c95aa6b9d3d7a2c5343f465d1a8631ee1df9f50",
                      "d50d-hlx-app13:3601/n2_agent_centos:11.0.2.1"
                    ],
                    "sizeBytes": 3223825508
                  },
                  {
                    "names": [
                      "d50d-hlx-app13:3601/ad_agent_centos@sha256:ebd885ce640a84903ed7a32ae4cd6dff526a074579831634ec9dfbe40b0962ea",
                      "d50d-hlx-app13:3601/ad_agent_centos:11.0.2.0"
                    ],
                    "sizeBytes": 1072047699
                  },
                  {
                    "names": [
                      "gcr.io/google-containers/kube-apiserver:v1.15.3"
                    ],
                    "sizeBytes": 206843838
                  },
                  {
                    "names": [
                      "httpd@sha256:3cbdff4bc16681541885ccf1524a532afa28d2a6578ab7c2d5154a7abc182379",
                      "httpd:latest"
                    ],
                    "sizeBytes": 165547282
                  },
                  {
                    "names": [
                      "gcr.io/google-containers/pause:3.1",
                      "gcr.io/google_containers/pause-amd64:3.1"
                    ],
                    "sizeBytes": 742472
                  }
                ]
              }
            }
          ]
        },
        "output": [
          "d50d-hlx-app13:3601/n2_agent_centos:11.0.2.1"
        ]
      }
    ],
    "identifier": 63734373
  },
  {
    "context": [
      "I have this JSON file and want to delete an element from an array:",
      "{\n\"address\": \"localhost\",\n\"name\": \"local\",\n\"vars\": {\n    \"instances\": [\n        \"one\",\n        \"two\"\n    ]\n  }\n}",
      "Is there any workaround to get the same result in v1.5?",
      "One portable to work with on both versions would be,\n\n    .vars.instances |= map(select(index(\"one\")|not))",
      "or if you want to still use `del()`, feed the index of the string `\"one\"` to the function as below, where `index(\"one\")` gets the index `0` which then gets passed to delete as `del(.[0])` meaning to delete the element at zeroth index.\n\n    .vars.instances |= del(.[index(\"one\")])"
    ],
    "utterance": "Remove the element with value \"one\" from the \"instances\" array inside the \"vars\" object.",
    "expressions": [
      ".vars.instances |= map(select(index(\"one\")|not))",
      ".vars.instances |= del(.[index(\"one\")])"
    ],
    "data": [
      {
        "input": {
          "address": "localhost",
          "name": "local",
          "vars": {
            "instances": [
              "one",
              "two"
            ]
          }
        },
        "output": {
          "address": "localhost",
          "name": "local",
          "vars": {
            "instances": [
              "two"
            ]
          }
        }
      }
    ],
    "identifier": 63741888
  },
  {
    "context": [
      "What I want is for both items with a null team to inherit their team value from the their parent.  If their parent's team is null look at their parents parent and so on.  In the above example team would be \"Team 1\" for both Item C and Item D.  If Item C has a parent of Item B then Items C and D should have a parent of \"Team 2\".",
      "def func($collection; $parent): \n    if $parent == null or $parent == \"\" then \n        null \n    else $collection \n        | .[] \n        | select(.name==$parent)\n        | .team // func($collection; .parent)\n    end;  \n        \n. as $collection\n    | map(.team = (.team // func($collection; .parent))) ",
      "Here's a solution using a recursive function to \"fill-in\" the dictionary constructed by INDEX(.[]; .name):\n# $ix to handle the case of no parent having a team\ndef team($name; $ix):\n  if $name == null or $ix == 0 then null\n  else .[$name].team // team(.[$name].parent; $ix-1)\n  end;\n  \nINDEX(.[]; .name) \n| reduce keys_unsorted[] as $k (.; .[$k].team = team($k; length))\n| [.[]]"
    ],
    "utterance": "For each item, assign the team value from its parent if its own team is null, recursively looking up the ancestry until a non-null team is found or there are no more parents.",
    "expressions": [
      "def func($collection; $parent): \n    if $parent == null or $parent == \"\" then \n        null \n    else $collection \n            | .[] \n            | select(.name==$parent)\n            | .team // func($collection; .parent)\n    end;  \n. as $collection\n| map(.team = (.team // func($collection; .parent)))",
      "def team($name; $ix):\n  if $name == null or $ix == 0 then null\n  else .[$name].team // team(.[$name].parent; $ix-1)\n  end;\n  \nINDEX(.[]; .name) \n| reduce keys_unsorted[] as $k (.; .[$k].team = team($k; length))\n| [.[]]"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Item A",
            "parent": "",
            "team": "Team 1"
          },
          {
            "name": "Item B",
            "parent": "Item A",
            "team": "Team 2"
          },
          {
            "name": "Item C",
            "parent": "Item A",
            "team": null
          },
          {
            "name": "Item D",
            "parent": "Item C",
            "team": null
          }
        ],
        "output": [
          {
            "name": "Item A",
            "parent": "",
            "team": "Team 1"
          },
          {
            "name": "Item B",
            "parent": "Item A",
            "team": "Team 2"
          },
          {
            "name": "Item C",
            "parent": "Item A",
            "team": "Team 1"
          },
          {
            "name": "Item D",
            "parent": "Item C",
            "team": "Team 1"
          }
        ]
      }
    ],
    "identifier": 63693030
  },
  {
    "context": [
      "Given the following JSON (oversimplified for the sake of the example), I need to order the keys by their value. In this case, the order should be id > name > type.",
      "EXPECTED RESULT:",
      "{ \"link\": [{ \"attributes\": [{ \"value\": \"0026a8b4-ced6-410e-9213-e3fcb28b3aab\", \"name\": \"id\" }, { \"value\": \"NAME1\", \"name\": \"name\" }, { \"value\": \"ConfigurationElement\", \"name\": \"type\" }], ... }, ...], \"total\": 2 }",
      "You can do:\n\njq '.link[].attributes|=sort_by(.name)'"
    ],
    "utterance": "Reorder each object's attributes array so entries with name \"id\" come first, then \"name\", then \"type\".",
    "expressions": [
      ".link[].attributes |= sort_by(.name)"
    ],
    "data": [
      {
        "input": {
          "link": [
            {
              "attributes": [
                {
                  "value": "ConfigurationElement",
                  "name": "type"
                },
                {
                  "value": "NAME1",
                  "name": "name"
                },
                {
                  "value": "0026a8b4-ced6-410e-9213-e3fcb28b3aab",
                  "name": "id"
                }
              ],
              "href": "href1",
              "rel": "down"
            },
            {
              "attributes": [
                {
                  "value": "0026a8b4-ced6-410e-9213-k23g15h2u1l5",
                  "name": "id"
                },
                {
                  "value": "ConfigurationElement",
                  "name": "type"
                },
                {
                  "value": "NAME2",
                  "name": "name"
                }
              ],
              "href": "href2",
              "rel": "down"
            }
          ],
          "total": 2
        },
        "output": {
          "link": [
            {
              "attributes": [
                {
                  "value": "0026a8b4-ced6-410e-9213-e3fcb28b3aab",
                  "name": "id"
                },
                {
                  "value": "NAME1",
                  "name": "name"
                },
                {
                  "value": "ConfigurationElement",
                  "name": "type"
                }
              ],
              "href": "href1",
              "rel": "down"
            },
            {
              "attributes": [
                {
                  "value": "0026a8b4-ced6-410e-9213-k23g15h2u1l5",
                  "name": "id"
                },
                {
                  "value": "NAME2",
                  "name": "name"
                },
                {
                  "value": "ConfigurationElement",
                  "name": "type"
                }
              ],
              "href": "href2",
              "rel": "down"
            }
          ],
          "total": 2
        }
      }
    ],
    "identifier": 63739892
  },
  {
    "context": [
      "uuid=$(jq '.id' <<< \"$uuid_json\")",
      "echo $uuid",
      "But it really should be: 069a79f444e94726a5befca90e38aaf5 for the curl command to work.",
      "jq has option to remove them it's -r with that everything works as expected(I think).",
      "So change it to: uuid=$(jq -r '.id' <<< \"$uuid_json\")"
    ],
    "utterance": "Extract the value of the id field as an unquoted string from an object where id is present.",
    "expressions": [
      ".id",
      "-r .id"
    ],
    "data": [
      {
        "input": {
          "name": "Notch",
          "id": "069a79f444e94726a5befca90e38aaf5"
        },
        "output": "069a79f444e94726a5befca90e38aaf5"
      }
    ],
    "identifier": 63762028
  },
  {
    "context": [
      "I need as a part of jq transformation to set some field to some random/sequential value.",
      "Suppose the file data.json contains a stream of JSON objects:\n{}\n{}\n{}\n",
      "Then a run of the following bash commands produced the output as shown below:\n\nn=$(stream | jq -n 'reduce inputs as $x (0; .+1)')\ngshuf -i 0-100 -r -n $n --random-source=/dev/random | \n  jq -cnR --slurpfile stream data.json '$stream[] | .random=input'\nOutput:\n{\"random\":\"17\"}\n{\"random\":\"69\"}\n{\"random\":\"81\"}",
      "od -t x -An /dev/random | tr -d \" \" | fold -w 8 |\n  jq -nRc --slurpfile stream data.json '$stream[] | .random=input'\nOutput:\n{\"random\":\"79c434e6\"}\n{\"random\":\"28797cf9\"}\n{\"random\":\"90a8813d\"}",
      "stream | while read -r obj ; do\n    echo \"$obj\"\n    gshuf -i 0-100 -n 1 --random-source=/dev/random\ndone | jq -nc 'repeat(input |  (.random = input))?'",
      "The function takes a parameter $state and delivers a newState in the response for a subsequent call of nextRandomNumber.",
      "jq -n --argjson initialRandomNumber \"$RANDOM$RANDOM\" '\n  ...\n  foreach inputs as $input (nextRandomNumber($initialRandomNumber); \n                            nextRandomNumber(.newState); \n                            $input + {randomNumber})\n'"
    ],
    "utterance": "For each object in the input stream, add a field whose value is a unique randomly generated number or string.",
    "expressions": [
      "jq -cnR --slurpfile stream data.json '$stream[] | .random=input'",
      "jq -nc 'repeat(input |  (.random = input))?'",
      "jq -n --argjson initialRandomNumber \"$RANDOM$RANDOM\" '\n  def nextRandomNumber($state):\n    ( (214013 * $state) + 2531011) % 2147483648\n    | { newState: ., randomNumber: (. / 65536 | floor) };\n\n  foreach inputs as $input (nextRandomNumber($initialRandomNumber);\n                            nextRandomNumber(.newState);\n                            $input + {randomNumber})\n'"
    ],
    "data": [
      {
        "input": [
          {},
          {},
          {}
        ],
        "output": [
          {
            "random": "17"
          },
          {
            "random": "69"
          },
          {
            "random": "81"
          }
        ]
      },
      {
        "input": [
          {},
          {},
          {}
        ],
        "output": [
          {
            "random": "79c434e6"
          },
          {
            "random": "28797cf9"
          },
          {
            "random": "90a8813d"
          }
        ]
      }
    ],
    "identifier": 63689970
  },
  {
    "context": [
      "Now I want to create a new variable from my JSON data. My CURL should look like this at the end:\r\n\r\n    curl -s -v -X POST --data '{\r\n        \"deleteEntries\": [\r\n            {\r\n                \"readID\": \"myID1\",\r\n                \"date\": \"2020-09-05T10:57:11Z\", <--Value from addDate\r\n                \"content\": \"abcd\"\r\n            },\r\n    \t\t{\r\n                \"readID\": \"myID2\",\r\n                \"date\": \"2020-09-05T06:58:52Z\", <--Value from addDate\r\n                \"content\": \"abc\"\r\n            }\r\n        ]\r\n    }'",
      "jq -j '.response | .data[] | .id + \"\\u001f\" + .content + \"\\u0000\"' \\",
      "for k in $(echo $ZONE_LIST  | jq -rc '.response | .data[]'); do\n    echo $k|jq '.content + \" - \" + .id' -r\ndone"
    ],
    "utterance": "Extract an array of objects, each containing the fields readID set to id, date set to addDate, and content (with content unescaped), from every item in response.data.",
    "expressions": [
      ".response.data | map({readID: .id, date: .addDate, content: (.content | fromjson)})"
    ],
    "data": [
      {
        "input": {
          "errors": [],
          "metadata": {
            "transactionId": ""
          },
          "response": {
            "data": [
              {
                "accountId": "xyz",
                "addDate": "2020-09-05T10:57:11Z",
                "content": "\"abcd\"",
                "id": "myID1",
                "lastChangeDate": "2020-09-05T10:57:11Z"
              },
              {
                "accountId": "xyz",
                "addDate": "2020-09-05T06:58:52Z",
                "content": "\"abc\"",
                "id": "myID2",
                "lastChangeDate": "2020-09-05T07:08:15Z"
              }
            ],
            "limit": 10,
            "page": 1,
            "totalEntries": 2
          },
          "status": "success",
          "warnings": []
        },
        "output": [
          {
            "readID": "myID1",
            "date": "2020-09-05T10:57:11Z",
            "content": "abcd"
          },
          {
            "readID": "myID2",
            "date": "2020-09-05T06:58:52Z",
            "content": "abc"
          }
        ]
      }
    ],
    "identifier": 63753704
  },
  {
    "context": [
      "The desired output is below. **Please note that the name and number of label are not fixed.**",
      "beta.kubernetes.io/arch=amd64;beta.kubernetes.io/os=linux;node-role.kubernetes.io/master=",
      "jq -r '.items[].metadata.labels| to_entries|map(\"\\(.key)=\\(.value)\") |join(\";\")'"
    ],
    "utterance": "For each object in items, return a string with all keys and values from metadata.labels joined as key=value pairs separated by semicolons.",
    "expressions": [
      ".items[].metadata.labels | to_entries | map(\"\u0018.key)=\u0018.value)\") | join(\";\")"
    ],
    "data": [
      {
        "input": {
          "metadata": {
            "selfLink": "/api/v1/nodes",
            "resourceVersion": "6666628"
          },
          "items": [
            {
              "metadata": {
                "name": "d50d-sa-app23",
                "selfLink": "/api/v1/nodes/d50d-sa-app23",
                "uid": "86a0e0b7-e9da-4489-86bd-0b6a7aafe102",
                "resourceVersion": "6666622",
                "creationTimestamp": "2020-07-07T12:34:08Z",
                "labels": {
                  "beta.kubernetes.io/arch": "amd64",
                  "beta.kubernetes.io/os": "linux",
                  "node-role.kubernetes.io/master": ""
                }
              }
            }
          ]
        },
        "output": "beta.kubernetes.io/arch=amd64;beta.kubernetes.io/os=linux;node-role.kubernetes.io/master="
      }
    ],
    "identifier": 63770596
  },
  {
    "context": [
      "I would ideally like to loop through these entries, do a check and then perform operations based on the check. So conceptually:",
      "\"for i in $(./sacli ClusterQuery | jq -r '<some syntax to get each key, value>'); do\n  node_id=key\n  ip=value.sacli_ip\n\n  ping -c 1 -W 1 $ip\n  ping_result=$?\n\n  if [[ $ping_result -eq 1 ]]; then #ping has failed\n     ./remove $node_id\n  fi\ndone\"",
      "I'd avoid your `for` loop in favor of piping to `while`, like this:\n```\n./sacli ClusterQuery | jq -rc '\n    keys_unsorted[] as $k | $k, .[$k].sacli_ip' |\n  while read -r node_id ; do\n    read -r ip\t \n    ping -c 1 -W 1 \"$ip\"\n    ping_result=$?\n    if [[ $ping_result -eq 1 ]]; then #ping has failed\n      echo ./remove \"$node_id\"\n    fi\n  done\n```",
      "You can of course easily add the appropriate `select` filter(s) inside the jq program."
    ],
    "utterance": "Extract each top-level key together with its sacli_ip value.",
    "expressions": [
      "keys_unsorted[] as $k | $k, .[$k].sacli_ip"
    ],
    "data": [
      {
        "input": {
          "i-aaaaaaabbbbbbbbbb": {
            "sacli_ip": "10.0.52.37",
            "sacli_listen_ip": "10.0.52.37",
            "sacli_port": "945"
          },
          "i-ccccccccddddddddd": {
            "sacli_ip": "10.0.48.68",
            "sacli_listen_ip": "10.0.48.68",
            "sacli_port": "945"
          }
        },
        "output": [
          "i-aaaaaaabbbbbbbbbb",
          "10.0.52.37",
          "i-ccccccccddddddddd",
          "10.0.48.68"
        ]
      }
    ],
    "identifier": 63757814
  },
  {
    "context": [
      "It basically concatenates multiple ports per item into 1 line and put extra port{n} as a prefix.",
      ".items[].spec | [.ports | range(0;length) as $ix | .[$ix] | to_entries | map(\"port\\($ix+1|leadingZeros(2))\\(.key)=\\(.value)\") | join(\";\") ] | join(\";\")"
    ],
    "utterance": "For each item, output all ports as a single line with keys prefixed by portNN (where NN is a two-digit index), separating each key-value pair with a semicolon.",
    "expressions": [
      "def leadingZeros($n): tostring | \"0\"*($n - length) + .;\n.items[].spec\n| [.ports\n   | range(0;length) as $ix\n   | .[$ix]\n   | to_entries\n   | map(\"port\\($ix+1|leadingZeros(2))\\(.key)=\\(.value)\")\n   | join(\";\") ]\n| join(\";\")"
    ],
    "data": [
      {
        "input": {
          "kind": "ServiceList",
          "apiVersion": "v1",
          "items": [
            {
              "spec": {
                "ports": [
                  {
                    "name": "https",
                    "protocol": "TCP",
                    "port": 443,
                    "targetPort": 6443
                  },
                  {
                    "name": "http",
                    "protocol": "TCP",
                    "port": 80,
                    "targetPort": 8080
                  }
                ],
                "clusterIP": "10.233.0.1",
                "type": "ClusterIP",
                "sessionAffinity": "None"
              },
              "status": {
                "loadBalancer": {}
              }
            },
            {
              "spec": {
                "ports": [
                  {
                    "protocol": "TCP",
                    "port": 80,
                    "targetPort": 80,
                    "nodePort": 40001
                  }
                ],
                "selector": {
                  "run": "my-httpd"
                },
                "clusterIP": "10.233.27.102",
                "type": "NodePort",
                "sessionAffinity": "None",
                "externalTrafficPolicy": "Cluster"
              },
              "status": {
                "loadBalancer": {}
              }
            }
          ]
        },
        "output": [
          "port01name=https;port01protocol=TCP;port01port=443;port01targetPort=6443;port02name=http;port02protocol=TCP;port02port=80;port02targetPort=8080",
          "port01protocol=TCP;port01port=80;port01targetPort=80;port01nodePort=40001"
        ]
      }
    ],
    "identifier": 63771419
  },
  {
    "context": [
      "key=\"supplier\"\nvalue=\"Wisozk Inc\"\njq \".[] | select(.$key==$value)\" customers.json",
      "It throws the following error\n\njq: error: syntax error, unexpected IDENT, expecting ';' or ')' (Unix shell quoting issues?) at <top-level>, line 1:\n.[] | select(.supplier == Wisozk Inc)\njq: 1 compile error",
      "Just pass your variables to `jq`'s context using the `--arg` field and let it deal with it.\n\n    jq --arg k supplier --arg v \"Wisozk Inc\" 'map(select(.[$k] == $v))' json"
    ],
    "utterance": "Return all objects where the value of the key 'supplier' is 'Wisozk Inc'.",
    "expressions": [
      "jq --arg k supplier --arg v \"Wisozk Inc\" 'map(select(.[$k] == $v))' customers.json"
    ],
    "data": [
      {
        "input": [
          {
            "_id": "5968dd23fc13ae04d9000001",
            "product_name": "sildenafil citrate",
            "supplier": "Wisozk Inc",
            "quantity": 262,
            "unit_cost": "$1047"
          },
          {
            "_id": "5968dd23fc13ae04d9000002",
            "product_name": "Mountain Juniperus ashei",
            "supplier": "Keebler-Hilpert",
            "quantity": 292,
            "unit_cost": "$874"
          },
          {
            "_id": "5968dd23fc13ae04d9000003",
            "product_name": "Dextromathorphan HBr",
            "supplier": "Schmitt-Weissnat",
            "quantity": 211,
            "unit_cost": "$2053"
          }
        ],
        "output": [
          {
            "_id": "5968dd23fc13ae04d9000001",
            "product_name": "sildenafil citrate",
            "supplier": "Wisozk Inc",
            "quantity": 262,
            "unit_cost": "$1047"
          }
        ]
      }
    ],
    "identifier": 63776066
  },
  {
    "context": [
      "file1:\n{\n    \"status\": {\n        \"errorCode\": 0,\n        \"recordsTotal\": 6,\n        \"recordsInResponse\": 2\n    },\n    \"records\": [\n        {\n            \"itemID\": 128,\n            \"name\": \"foo barn\"\n        },\n        {\n            \"itemID\": 64,\n            \"name\": \"fee fom\"\n        }\n    ]\n}",
      "file2:\n{\n    \"status\": {\n        \"errorCode\": 0,\n        \"recordsTotal\": 6,\n        \"recordsInResponse\": 2\n    },\n    \"records\": [\n        {\n            \"itemID\": 32,\n            \"name\": \"pim pom\"\n        },\n        {\n            \"itemID\": 256,\n            \"name\": \"ping pong\"\n        }\n    ]\n}",
      "wanted:\n\"records\": [ // records array is not needed, having just items iterated is fine as well.\n    {\n        \"itemID\": 128,\n        \"name\": \"foo barn\"\n    },\n    {\n        \"itemID\": 64,\n        \"name\": \"fee fom\"\n    },\n    {\n        \"itemID\": 32,\n        \"name\": \"pim pom\"\n    },\n    {\n        \"itemID\": 256,\n        \"name\": \"ping pong\"\n    }\n]",
      "Use `-s` to create one array from both the files, than use `.[0]` and `.[1]` to get each file's structure.\n\n    jq -s '.[0].records + .[1].records' file1 file2",
      "To include the toplevel key, wrap the expression to an object:\n\n    jq -s '{records: (.[0].records + .[1].records)}' file1 file2",
      "You can avoid creating an initial array with `inputs`.\n\n(A) If you just want the objects\n\n    jq -n 'inputs | .records[]'",
      "(B) If you want the objects in an array\n\n    jq -n 'reduce inputs as $in ([]; . += ($in.records))'",
      "(C) If you want the objects in an array named \"records\"\n\n    jq -n 'reduce inputs as $in ({}; .[\"records\"] += ($in.records))'"
    ],
    "utterance": "Combine the arrays under the 'records' key from two files so that all record objects appear together, optionally inside a 'records' array or as individual items.",
    "expressions": [
      "jq -s '.[0].records + .[1].records' file1 file2",
      "jq -s '{records: (.[0].records + .[1].records)}' file1 file2",
      "jq -n 'inputs | .records[]'",
      "jq -n 'reduce inputs as $in ([]; . += ($in.records))'",
      "jq -n 'reduce inputs as $in ({}; .[\"records\"] += ($in.records))'"
    ],
    "data": [
      {
        "input": {
          "file1": {
            "status": {
              "errorCode": 0,
              "recordsTotal": 6,
              "recordsInResponse": 2
            },
            "records": [
              {
                "itemID": 128,
                "name": "foo barn"
              },
              {
                "itemID": 64,
                "name": "fee fom"
              }
            ]
          },
          "file2": {
            "status": {
              "errorCode": 0,
              "recordsTotal": 6,
              "recordsInResponse": 2
            },
            "records": [
              {
                "itemID": 32,
                "name": "pim pom"
              },
              {
                "itemID": 256,
                "name": "ping pong"
              }
            ]
          }
        },
        "output": [
          {
            "itemID": 128,
            "name": "foo barn"
          },
          {
            "itemID": 64,
            "name": "fee fom"
          },
          {
            "itemID": 32,
            "name": "pim pom"
          },
          {
            "itemID": 256,
            "name": "ping pong"
          }
        ]
      }
    ],
    "identifier": 63768922
  },
  {
    "context": [
      "$ echo $a | jq '.[] | select(.location==\"Stockholm\")'",
      "Instead I want the output to be a json list like this:",
      "[  ",
      "  {",
      "    \"name\": \"Donald\",",
      "    \"location\": \"Stockholm\"",
      "  },",
      "  {",
      "    \"name\": \"Walt\",",
      "    \"location\": \"Stockholm\"",
      "  }",
      "]",
      "In general, you can stick square brackets around any expression to gather all its outputs into an array.",
      "[.[] | select(.location==\"Stockholm\")]"
    ],
    "utterance": "Return an array of all objects whose location is \"Stockholm\".",
    "expressions": [
      "[.[] | select(.location==\"Stockholm\")]"
    ],
    "data": [
      {
        "input": {
          "FOO": {
            "name": "Donald",
            "location": "Stockholm"
          },
          "BAR": {
            "name": "Walt",
            "location": "Stockholm"
          },
          "BAZ": {
            "name": "Jack",
            "location": "Whereever"
          }
        },
        "output": [
          {
            "name": "Donald",
            "location": "Stockholm"
          },
          {
            "name": "Walt",
            "location": "Stockholm"
          }
        ]
      }
    ],
    "identifier": 63801953
  },
  {
    "context": [
      "Whole json structure to be kept, but in one array I'd like to remove all values but one on given index.",
      "Input:\n\n    {\n        \"a\": {\n            \"b\": [11,22,33,44]\n        }\n        \n    }",
      "Desired output:\n\n    {\n        \"a\": {\n            \"b\": [22]\n        }\n        \n    }",
      "**All I have on input to identify item to be deleted is its index in array.**",
      "If $i is the relevant index:\n\n    .a.b |= [.[$i]]",
      "For example:\n\n    jq --argjson i 1 '.a.b |= [.[$i]]' input.json"
    ],
    "utterance": "Keep everything unchanged except in the path a.b, where only the element at a given index remains and all others are removed from the array.",
    "expressions": [
      ".a.b |= [.[$i]]"
    ],
    "data": [
      {
        "input": {
          "a": {
            "b": [
              11,
              22,
              33,
              44
            ]
          }
        },
        "output": {
          "a": {
            "b": [
              22
            ]
          }
        }
      }
    ],
    "identifier": 63813622
  },
  {
    "context": [
      "I am trying to get the `ActionId` and *not* \"Status=OK\" in the following JSON with jq.",
      "It doesn't work because `_source` contains the underscore character.",
      "jq ._source.ActionId",
      "cat so.json | jq ._source.ActionId"
    ],
    "utterance": "Select the value of the ActionId field located inside the _source object at the top level of each array item.",
    "expressions": [
      "._source.ActionId"
    ],
    "data": [
      {
        "input": [
          {
            "_index": "filebeat-7.2.0-2020.09.06-000060",
            "_type": "_doc",
            "_version": 1,
            "_score": null,
            "_source": {
              "@timestamp": "2020-09-09T11:34:21.192Z",
              "ActionName": "Service",
              "ConnectionId": "53NCBP",
              "Method": "POST",
              "ActionId": "ecdc38f369e3",
              "stream": "stdout",
              "RequestId": "0HM2D6Q53NC1",
              "Status": "OK",
              "@t": "2020-09-09T11:34:21.1926712Z",
              "input": {
                "type": "docker"
              },
              "IP": "1.1.1.1"
            },
            "fields": {
              "@timestamp": [
                "2020-09-09T11:34:21.192Z"
              ],
              "s.timestamp": [
                "2020-09-09T11:34:21.192Z"
              ]
            },
            "sort": [
              1599651261192
            ]
          }
        ],
        "output": [
          "ecdc38f369e3"
        ]
      }
    ],
    "identifier": 63812530
  },
  {
    "context": [
      "I'm using `jq` to transform a JSON input with some nested dynamic keys in this format:",
      "... into an array of objects in this format:",
      "I've managed to do it using:",
      "jq 'to_entries | map_values({\n  name: .key,\n  version: .value|keys[0],\n  regular: .value[.value|keys[0]].size.regular,\n  compressed: .value[.value|keys[0]].size.compressed\n})' input.json",
      "Is there a way to access the dynamic keys of each level in the original JSON so I can use them as values in my output with less repetition?",
      "You could use jq's so-called \"$-variables\", e.g.\n```\nto_entries\n| map_values(\n    (.value|keys[0]) as $innerkey\n    | { name: .key,\n        version: $innerkey,\n        regular: .value[$innerkey].size.regular,\n        compressed: .value[$innerkey].size.compressed\n})",
      "You could also introduce a variable for `.value[$innerkey].size`, or better yet, simplify:\n```\nto_entries\n| map_values(\n    (.value|keys[0]) as $innerkey\n    | { name: .key, version: $innerkey }\n      + .value[$innerkey].size )"
    ],
    "utterance": "Convert nested objects with dynamic package and version keys into an array where each entry includes the package name, version, and values of regular and compressed size.",
    "expressions": [
      "to_entries | map_values((.value|keys[0]) as $innerkey | { name: .key, version: $innerkey, regular: .value[$innerkey].size.regular, compressed: .value[$innerkey].size.compressed })",
      "to_entries | map_values((.value|keys[0]) as $innerkey | { name: .key, version: $innerkey } + .value[$innerkey].size )"
    ],
    "data": [
      {
        "input": {
          "somePackage": {
            "someVersion": {
              "size": {
                "regular": 1234,
                "compressed": 123
              }
            }
          },
          "someOtherPackage": {
            "someOtherVersion": {
              "size": {
                "regular": 5678,
                "compressed": 567
              }
            }
          }
        },
        "output": [
          {
            "name": "somePackage",
            "version": "someVersion",
            "regular": 1234,
            "compressed": 123
          },
          {
            "name": "someOtherPackage",
            "version": "someOtherVersion",
            "regular": 5678,
            "compressed": 567
          }
        ]
      }
    ],
    "identifier": 63800060
  },
  {
    "context": [
      "\"I want to append to the .routing.rules[].inboundTag array where the outboundTag has the value of \\\"vpn-out\\\". At the same time I want the modified root object returned so that I can save it into a bash variable.\"",
      "\"You need to only mark \\\"that\\\" desired object for update, ways you can do that would be to use below which selects the update to be performed from the standpoint of the rootnode.\"",
      "\"( .routing.rules[] |  select(.outboundTag==$out_tag) | .inboundTag ) += [$in_tag]\"",
      "\"One other way would be to use the update assignment operator |=, to select the object under rules containing your outbound tag and append to its inboundTag\"",
      "\".routing.rules |= ( map(select(.outboundTag==$out_tag).inboundTag += [$in_tag]  ) )\""
    ],
    "utterance": "Append a value to inboundTag in rules where outboundTag equals \"vpn-out\" and return the full, modified object.",
    "expressions": [
      "( .routing.rules[] | select(.outboundTag==$out_tag) | .inboundTag ) += [$in_tag]",
      ".routing.rules |= ( map(select(.outboundTag==$out_tag).inboundTag += [$in_tag]  ) )"
    ],
    "data": [
      {
        "input": {
          "routing": {
            "rules": [
              {
                "type": "field",
                "inboundTag": [
                  "input"
                ],
                "outboundTag": "vpn-out"
              },
              {
                "type": "field",
                "inboundTag": [
                  "alternate"
                ],
                "outboundTag": "raw-out"
              }
            ]
          }
        },
        "output": {
          "routing": {
            "rules": [
              {
                "type": "field",
                "inboundTag": [
                  "input",
                  "NEW_TAG"
                ],
                "outboundTag": "vpn-out"
              },
              {
                "type": "field",
                "inboundTag": [
                  "alternate"
                ],
                "outboundTag": "raw-out"
              }
            ]
          }
        }
      }
    ],
    "identifier": 63807082
  },
  {
    "context": [
      "jq 'to_entries[] '\"${OPTIONAL_FILTER}\"' | .value.name' <<< $JSON",
      "jq \"to_entries[] ${OPTIONAL_FILTER} | .value.name\" <<< $JSON",
      "jq --arg flag \"$FLAG\" '\n  to_entries[]\n  | if $flag == \"value\" then select(.key == \"key2\")\n    else . end\n  | .value.name' <<< $JSON"
    ],
    "utterance": "Dynamically apply a filter to select only the entry with key equal to \"key2\" if FLAG equals \"value\"; otherwise, return the names of all entries.",
    "expressions": [
      "jq 'to_entries[] '\"${OPTIONAL_FILTER}\"' | .value.name' <<< $JSON",
      "jq \"to_entries[] ${OPTIONAL_FILTER} | .value.name\" <<< $JSON",
      "jq --arg flag \"$FLAG\" '\n  to_entries[]\n  | if $flag == \"value\" then select(.key == \"key2\")\n    else . end\n  | .value.name' <<< $JSON"
    ],
    "data": [
      {
        "input": {
          "key1": {
            "name": "foo"
          },
          "key2": {
            "name": "bar"
          }
        },
        "output": [
          "\"foo\"",
          "\"bar\""
        ]
      },
      {
        "input": {
          "key1": {
            "name": "foo"
          },
          "key2": {
            "name": "bar"
          }
        },
        "output": [
          "\"bar\""
        ]
      }
    ],
    "identifier": 63816061
  },
  {
    "context": [
      "i have two json files that i would like to merge based on the value of a key. the key name is different in both json files but the value would be the same.",
      "sample1.json",
      "{ \"unique_id\": \"pp1234\", ... }",
      "sample2.json",
      "{ \"netid\": \"pp1234\", ... }",
      "i would want the output to look something like:",
      "results.json",
      "{ \"unique_id\": \"pp1234\", ..., \"mailing_state\": \"New York\", ... }",
      "order of results would not matter as long as the records are merged based on netid/unique_id keys.",
      "the following invocation should do the trick:",
      "jq --argfile uid sample1.json '\n  ($uid | INDEX(.unique_id)) as $dict\n  | map( $dict[.netid] + del(.netid) )\n' sample2.json"
    ],
    "utterance": "Merge two lists of objects where each object is matched by unique_id from the first list and netid from the second list, combining properties from both objects with matching values.",
    "expressions": [
      "jq --argfile uid sample1.json '($uid | INDEX(.unique_id)) as $dict | map($dict[.netid] + del(.netid))' sample2.json"
    ],
    "data": [
      {
        "input": [
          {
            "unique_id": "pp1234",
            "unique_id_type": "netid",
            "rfid": "12245556890478"
          },
          {
            "unique_id": "aqe123",
            "unique_id_type": "netid",
            "rfid": "12234556890478"
          }
        ],
        "output": [
          {
            "unique_id": "pp1234",
            "unique_id_type": "netid",
            "rfid": "12245556890478",
            "mailing_state": "New York",
            "mobile_phone_number": "(982) 2541212",
            "netid_reachable": "Y"
          },
          {
            "unique_id": "aqe123",
            "unique_id_type": "netid",
            "rfid": "12234556890478",
            "mailing_state": "New York",
            "mobile_phone_number": "(982) 5551212",
            "netid_reachable": "Y"
          }
        ]
      }
    ],
    "identifier": 63819013
  },
  {
    "context": [
      "I want to print a VPC id and group id in one line and so on for another objects.",
      "If the JSON file is just an array of the objects, you don&#39;t need to loop over them in bash. `jq` will loop over them implicitely:",
      "jq -r '.[][][] | (.VpcId + \"||\" + .GroupId)' file.json",
      "Output:\nvpc-123||sg\nvpc-12345||sg-12345"
    ],
    "utterance": "For each object in the input, output its VpcId and GroupId separated by '||' on a single line for all security groups.",
    "expressions": [
      ".[][][] | (.VpcId + \"||\" + .GroupId)"
    ],
    "data": [
      {
        "input": [
          {
            "SG": [
              {
                "Description": "des",
                "GroupName": "Gpname",
                "GroupId": "sg",
                "VpcId": "vpc-123"
              }
            ]
          },
          {
            "SG": [
              {
                "Description": "des",
                "GroupName": "xyz",
                "GroupId": "sg-12345",
                "VpcId": "vpc-12345"
              }
            ]
          }
        ],
        "output": [
          "vpc-123||sg",
          "vpc-12345||sg-12345"
        ]
      }
    ],
    "identifier": 63842811
  },
  {
    "context": [
      "So if a \"dev\" value in `abc.json` matches a \"dev\" key in `xyz.json` then I need to replace the value in `abc.json` by the corresponding value in `xyz.json`.",
      "`< abc.json jq --argfile vars xyz.json '\n  $vars.dev as $dict\n  | .dev |= map_values( $dict[.] // .)'\n`",
      "If you're squeamish about using --argfile, you could (for example) use --slurpfile instead, though in that case `$vars.dev` would be replaced by `$vars[0].dev`"
    ],
    "utterance": "Replace each value in the 'dev' object with the corresponding value from another file's 'dev' object, if the value matches a key in the other file.",
    "expressions": [
      "$vars.dev as $dict | .dev |= map_values($dict[.] // .)"
    ],
    "data": [
      {
        "input": {
          "abc.json": {
            "name": "testfile",
            "version": "1.0",
            "dev": {
              "LoggingLevel": "DEBUG",
              "logging.level.HikariPool": "DEBUG",
              "spring.testname": "@@CONSENT_RW@@",
              "spring.testpassword": "@@CONSETNPWD@@"
            }
          },
          "xyz.json": {
            "name": "testset",
            "version": "1.0",
            "dev": {
              "@@CONSENT_RW@@": "ARM",
              "@@CONSETNPWD@@": "ARMPWD"
            }
          }
        },
        "output": {
          "name": "testfile",
          "version": "1.0",
          "dev": {
            "LoggingLevel": "DEBUG",
            "logging.level.HikariPool": "DEBUG",
            "spring.testname": "ARM",
            "spring.testpassword": "ARMPWD"
          }
        }
      }
    ],
    "identifier": 63819015
  },
  {
    "context": [
      "Could anyone else let me know how I could take the data I have and search it to see if it has token2?",
      "jq '.accounts[].tokens[] | select(. == \"tokens2\")",
      "the jq query:\n\n```\n.accounts | map(select(.tokens | index(\"tokens2\")) | .accountId)\n```\n\nfinds [\"account001\", \"account003\"] from the following data:"
    ],
    "utterance": "Return a list of accountId values for accounts whose tokens array includes the string 'tokens2'.",
    "expressions": [
      ".accounts | map(select(.tokens | index(\"tokens2\")) | .accountId)",
      "[ .accounts[] | select(.tokens | index(\"tokens2\")) | .accountId ]"
    ],
    "data": [
      {
        "input": {
          "accounts": [
            {
              "accountId": "account001",
              "tokens": [
                "tokens1",
                "tokens2",
                "tokens3",
                "tokens4"
              ]
            },
            {
              "accountId": "account002",
              "tokens": [
                "tokens3",
                "tokens4"
              ]
            },
            {
              "accountId": "account003",
              "tokens": [
                "tokens1",
                "tokens2"
              ]
            }
          ]
        },
        "output": [
          "account001",
          "account003"
        ]
      }
    ],
    "identifier": 63850964
  },
  {
    "context": [
      "The current command is:\n\njq '.result | .[].newValueJson.action |= (. | tostring // .) | .[].oldValueJson.action |= (. | tostring // .) | .[].metadata.value |= (. | tostring // .)'",
      "As you can see, the function \"tostring\" is being applied to \"newValueJson.action\", \"oldValueJson.action\" and \"metadata.value\" in just the same way. I am wondering if there is a more compact syntax so I only need to apply tostring once?",
      "You can group the actions together using `(..)` as below. Also instead of using the array notation `.[]`, you can use `map(..)` to handle apply the filter expression inside the `result` array",
      ".result | map((.newValueJson.action, .oldValueJson.action, .metadata.value ) |= (. | tostring // .))"
    ],
    "utterance": "Convert newValueJson.action, oldValueJson.action, and metadata.value to strings if they are not already.",
    "expressions": [
      ".result | map((.newValueJson.action, .oldValueJson.action, .metadata.value ) |= (. | tostring // .))"
    ],
    "data": [
      {
        "input": {
          "result": [
            {
              "id": 1,
              "action": {
                "result": true,
                "type": "filter_create"
              },
              "newValueJson": {
                "action": "simulate"
              },
              "oldValueJson": {
                "action": "enforce"
              },
              "metadata": {
                "value": false
              }
            },
            {
              "id": 2,
              "action": {
                "result": true,
                "type": "filter_create"
              },
              "newValueJson": {
                "action": {
                  "mode": "simulate",
                  "timeout": 3600
                }
              },
              "oldValueJson": {
                "action": {
                  "mode": "enforce",
                  "timeout": 3600
                }
              },
              "metadata": {
                "value": "off"
              }
            }
          ]
        },
        "output": [
          {
            "id": 1,
            "action": {
              "result": true,
              "type": "filter_create"
            },
            "newValueJson": {
              "action": "simulate"
            },
            "oldValueJson": {
              "action": "enforce"
            },
            "metadata": {
              "value": "false"
            }
          },
          {
            "id": 2,
            "action": {
              "result": true,
              "type": "filter_create"
            },
            "newValueJson": {
              "action": "{\"mode\":\"simulate\",\"timeout\":3600}"
            },
            "oldValueJson": {
              "action": "{\"mode\":\"enforce\",\"timeout\":3600}"
            },
            "metadata": {
              "value": "off"
            }
          }
        ]
      }
    ],
    "identifier": 63844909
  },
  {
    "context": [
      "I need to increment the abc-app's or xyz-app's version. At present its at \"20.02.01-16\" for abc-app and I need to change it to \"20.02.01-17\". Also I need to increment the tag of the parent app which is \"abc\"  to \"25\"",
      "The remainder of the solution can now be written in two lines, one for each value to be incremented:",
      ".tag |= inc",
      "| .apps |= map(if .name == \"abc-app\" then .version |= inc else . end)"
    ],
    "utterance": "Increment the tag field by 1, and increment the version number for the app named 'abc-app' by increasing the numeric suffix after the final dash.",
    "expressions": [
      "def inc: (capture(\"(?<pre>.*)-(?<post>[0-9]+$)\") | \"\\(.pre)-\\( (.post|tonumber) + 1 )\") // \"\\(tonumber+1)\" ; .tag |= inc | .apps |= map(if .name == \"abc-app\" then .version |= inc else . end)"
    ],
    "data": [
      {
        "input": {
          "name": "abc",
          "version": "20.02.01",
          "tag": "24",
          "abc_version": "20.02",
          "registry": "registry.abc.com",
          "vendor": "greenplanet",
          "apps": [
            {
              "name": "abc-app",
              "version": "20.02.01-16",
              "volumes": [
                "/dev/log:/dev/log"
              ],
              "max_instances": "1"
            },
            {
              "name": "xyz-app",
              "version": "2.0.0-2",
              "volumes": [
                "/dev/log:/dev/log"
              ],
              "max_instances": "1"
            }
          ]
        },
        "output": {
          "name": "abc",
          "version": "20.02.01",
          "tag": "25",
          "abc_version": "20.02",
          "registry": "registry.abc.com",
          "vendor": "greenplanet",
          "apps": [
            {
              "name": "abc-app",
              "version": "20.02.01-17",
              "volumes": [
                "/dev/log:/dev/log"
              ],
              "max_instances": "1"
            },
            {
              "name": "xyz-app",
              "version": "2.0.0-2",
              "volumes": [
                "/dev/log:/dev/log"
              ],
              "max_instances": "1"
            }
          ]
        }
      }
    ],
    "identifier": 63865464
  },
  {
    "context": [
      "the array is nested in the JSON file and has an unknown number of elements.",
      "while IFS= read -r addr; do\n  echo \"Handling address: $addr\"\ndone < <(jq -r '.Producers[].addr' <\"$NEW_PEERS_JSON\")",
      "This is much, much more efficient than running a separate copy of jq per item you want to extract."
    ],
    "utterance": "Extract all addr values from each object in the Producers array, regardless of array length.",
    "expressions": [
      ".Producers[].addr",
      ".Producers | .[].addr"
    ],
    "data": [
      {
        "input": {
          "resultcode": "201",
          "networkMagic": "764824073",
          "ipType": 4,
          "Producers": [
            {
              "addr": "xx.xxx.xxx.01",
              "port": 3030,
              "valency": 1,
              "distance": 14
            },
            {
              "addr": "xx.xxx.xxx.02",
              "port": 3001,
              "valency": 1,
              "distance": 955
            }
          ]
        },
        "output": [
          "xx.xxx.xxx.01",
          "xx.xxx.xxx.02"
        ]
      }
    ],
    "identifier": 63876705
  },
  {
    "context": [
      "I would like to get the values of  `key` and `field_1` to use them in the `curl` request.",
      "jq -r '.list[]|[.key,.fields.field_1]|@tsv' test.json",
      "test-11\t1234",
      "test-10\t1235"
    ],
    "utterance": "Extract pairs of key and field_1 values for all elements in list.",
    "expressions": [
      ".list[] | [.key, .fields.field_1] | @tsv",
      ".list[] | [ .key, .fields.field_1 ] | @tsv"
    ],
    "data": [
      {
        "input": {
          "list": [
            {
              "expand": "xx",
              "id": "xxxxx",
              "self": "https",
              "key": "test-11",
              "fields": {
                "field_1": "1234"
              }
            },
            {
              "expand": "xx",
              "id": "xxxxx",
              "self": "https",
              "key": "test-10",
              "fields": {
                "field_1": "1235",
                "field_2": null
              }
            }
          ]
        },
        "output": "test-11\t1234\ntest-10\t1235"
      }
    ],
    "identifier": 63877660
  },
  {
    "context": [
      "My bash line",
      "jq -r '.search_objects[].price' file",
      "print(jsonResponse[\"search_objects\"][\"price\"])\n\nBut fails :-("
    ],
    "utterance": "Extract all values of 'price' from each object in the 'search_objects' array.",
    "expressions": [
      ".search_objects[].price"
    ],
    "identifier": 63899314
  },
  {
    "context": [
      "if a specific key:value pair matches between the file, I want to update another (and only 1 other) key:value pair.",
      "I want to update b.json so that if the \"i\" value of b.json matches the \"i\" value of a.json, the value for \"f\" is replaced by a.json's value.",
      "only the f values must be replaced, not the ones for a.",
      "the following can be used to achieve the desired result:",
      "jq --argfile a a.json -f program.jq b.json",
      "`(INDEX($a[]; .i) | map_values(.f)) as $dict | map( .f = $dict[.i] )`"
    ],
    "utterance": "Update the value of 'f' in one file where the 'i' value matches another file, while keeping all other fields unchanged.",
    "expressions": [
      "(INDEX($a[]; .i) | map_values(.f)) as $dict | map( .f = $dict[.i] )"
    ],
    "data": [
      {
        "input": {
          "a": [
            {
              "i": "1234",
              "f": "123",
              "a": "0"
            },
            {
              "i": "1235",
              "f": "123",
              "a": "0"
            },
            {
              "i": "1236",
              "f": "123",
              "a": "0"
            },
            {
              "i": "1237",
              "f": "123",
              "a": "0"
            },
            {
              "i": "1238",
              "f": "123",
              "a": "0"
            }
          ],
          "b": [
            {
              "i": "1234",
              "f": "555",
              "a": "1"
            },
            {
              "i": "1235",
              "f": "555",
              "a": "1"
            },
            {
              "i": "1236",
              "f": "555",
              "a": "1"
            },
            {
              "i": "1237",
              "f": "555",
              "a": "1"
            },
            {
              "i": "1238",
              "f": "555",
              "a": "1"
            }
          ]
        },
        "output": [
          {
            "i": "1234",
            "f": "123",
            "a": "1"
          },
          {
            "i": "1235",
            "f": "123",
            "a": "1"
          },
          {
            "i": "1236",
            "f": "123",
            "a": "1"
          },
          {
            "i": "1237",
            "f": "123",
            "a": "1"
          },
          {
            "i": "1238",
            "f": "123",
            "a": "1"
          }
        ]
      }
    ],
    "identifier": 63879453
  },
  {
    "context": [
      "how can I assign and use these two arrays into vars directly in a single command not involving the intermediate files?",
      "Simply store the intermediate arrays as jq \"$-variables\":",
      "[.[].Header.Tenant] as $x\n| ([.[] | select (all(.Body.values[]; .name !=\"LoadTest\")  )  ] | [.[].Header.Tenant]) as $y\n| $x - $y",
      "If you want to itemize the contents of $x - $y, then simply add a final `.[]` to the pipeline.",
      "jq -r '{\n         \"all-tenants\": [.[].Header.Tenant],\n         \"filter1\": [.[]|select (all(.Body.values[]; .name !=\"LoadTest\"))]|[.[].Header.Tenant]\n       } | .[\"all-tenants\"] - .filter1 | .[]'"
    ],
    "utterance": "Output tenant names whose Body.values array contains at least one element with name equal to \"LoadTest\", without using intermediate files.",
    "expressions": [
      "[.[].Header.Tenant] as $x | ([.[] | select (all(.Body.values[]; .name !=\"LoadTest\"))] | [.[].Header.Tenant]) as $y | $x - $y | .[]",
      "{ \"all-tenants\": [.[].Header.Tenant], \"filter1\": [.[]|select (all(.Body.values[]; .name !=\"LoadTest\"))]|[.[].Header.Tenant] } | .[\"all-tenants\"] - .filter1 | .[]"
    ],
    "data": [
      {
        "input": [
          {
            "Header": {
              "Tenant": "tenant-1",
              "Rcode": 200
            },
            "Body": {
              "values": [
                {
                  "id": "0b0b-0c0c",
                  "name": "NumberOfSearchResults"
                },
                {
                  "id": "aaaa0001-0a0a",
                  "name": "LoadTest"
                }
              ]
            }
          },
          {
            "Header": {
              "Tenant": "tenant-2",
              "Rcode": 200
            },
            "Body": {
              "values": []
            }
          },
          {
            "Header": {
              "Tenant": "tenant-3",
              "Rcode": 200
            },
            "Body": {
              "values": [
                {
                  "id": "cccca0003-0b0b",
                  "name": "LoadTest"
                }
              ]
            }
          },
          {
            "Header": {
              "Tenant": "tenant-4",
              "Rcode": 200
            },
            "Body": {
              "values": [
                {
                  "id": "0f0g-0e0a",
                  "name": "NumberOfSearchResults"
                }
              ]
            }
          }
        ],
        "output": [
          "tenant-1",
          "tenant-3"
        ]
      }
    ],
    "identifier": 63874826
  },
  {
    "context": [
      "What I have: '[\"a\",\"b\",\"c\"]'",
      "What I want: {\n  \"1\":\"a\",\n  \"2\":\"b\",\n  \"3\":\"c\"\n}",
      "[to_entries[] | {(.key+1|tostring): .value}] | add",
      "with_entries(.key |= (1+.|tostring))",
      ". as $in\n| reduce range(0;length) as $i (null; \n    . + {($i+1|tostring): $in[$i]})"
    ],
    "utterance": "Convert an array to an object where keys are 1-based indices as strings and values are the array's elements.",
    "expressions": [
      "[to_entries[] | {(.key+1|tostring): .value}] | add",
      "with_entries(.key |= (1+.|tostring))",
      ". as $in | reduce range(0;length) as $i (null; . + {($i+1|tostring): $in[$i]})"
    ],
    "data": [
      {
        "input": [
          "a",
          "b",
          "c"
        ],
        "output": {
          "1": "a",
          "2": "b",
          "3": "c"
        }
      }
    ],
    "identifier": 63889946
  },
  {
    "context": [
      "I&#39;m trying to extract two fields (id and name) from the following output using jq. I&#39;m continually getting a compile error. I&#39;ve tried jq .result.id|.name among other variations.",
      "Try something like this: `jq &#39;.result[] | .id , .name&#39; data.json`.",
      "The main problem with the other command you tried is that `result` is an array, so you need to specify to iterate over it before you&#39;re able to extract `id` and `name` from the elements inside the array."
    ],
    "utterance": "Extract the id and name fields from each object in the result array.",
    "expressions": [
      ".result[] | .id , .name"
    ],
    "data": [
      {
        "input": {
          "result": [
            {
              "id": "6e55aff5ff4a74a234112c1d341b2e31",
              "zone_id": "d018a8f437462900bbe514c916a492a5",
              "zone_name": "example.com",
              "name": "example.com",
              "type": "A",
              "content": "98.158.193.66",
              "proxiable": true,
              "proxied": true,
              "ttl": 1,
              "locked": false,
              "meta": {
                "auto_added": false,
                "managed_by_apps": false,
                "managed_by_argo_tunnel": false,
                "source": "primary"
              },
              "created_on": "2020-09-14T12:48:23.952656Z",
              "modified_on": "2020-09-14T12:48:23.952656Z"
            },
            {
              "id": "3e1243be83fdaca735b419c224e670e7",
              "zone_id": "d018a8f437462900bbe514c916a492a5",
              "zone_name": "example.com",
              "name": "localhost.example.com",
              "type": "A",
              "content": "127.0.0.1",
              "proxiable": false,
              "proxied": false,
              "ttl": 14400,
              "locked": false,
              "meta": {
                "auto_added": false,
                "managed_by_apps": false,
                "managed_by_argo_tunnel": false,
                "source": "primary"
              },
              "created_on": "2020-09-14T12:17:53.68773Z",
              "modified_on": "2020-09-14T12:17:53.68773Z"
            }
          ]
        }
      }
    ],
    "identifier": 63885229
  },
  {
    "context": [
      "I have a nodekey file from which I want to take the address and append it in a genesis.json file.",
      "I want to fetch the address's value {4cb6046ae395bb6b5f9febc7bdcae28489268725} from this file and append it in the genesis.json file in nested key.",
      "In this file I want to append the address inside the alloc section at the end like this..",
      "jq --argfile node nodekey.json '.alloc += { ($node.address): {balance: \"1000000000000000000000000000\"} }' genesis.json"
    ],
    "utterance": "Insert the address from nodekey.json as a new key under the alloc object in genesis.json, with its value set to an object {\"balance\": \"1000000000000000000000000000\"}.",
    "expressions": [
      "jq --argfile node nodekey.json '.alloc += { ($node.address): {balance: \"1000000000000000000000000000\"} }' genesis.json"
    ],
    "data": [
      {
        "input": {
          "alloc": {
            "0xed9d02e382b34818e88b88a309c7fe71e65f419d": {
              "balance": "1000000000000000000000000000"
            },
            "0xca843569e3427144cead5e4d5999a3d0ccf92b8e": {
              "balance": "1000000000000000000000000000"
            }
          },
          "coinbase": "0x0000000000000000000000000000000000000000",
          "config": {
            "homesteadBlock": 0,
            "byzantiumBlock": 0,
            "constantinopleBlock": 0,
            "chainId": 10,
            "eip150Block": 0,
            "eip155Block": 0,
            "eip150Hash": "0x0000000000000000000000000000000000000000000000000000000000000000",
            "eip158Block": 0,
            "maxCodeSize": 35,
            "isQuorum": true
          },
          "difficulty": "0x0",
          "extraData": "0x0000000000000000000000000000000000000000000000000000000000000000",
          "gasLimit": "0xE0000000",
          "mixhash": "0x00000000000000000000000000000000000000647572616c65787365646c6578",
          "nonce": "0x0",
          "parentHash": "0x0000000000000000000000000000000000000000000000000000000000000000",
          "timestamp": "0x00"
        },
        "output": {
          "alloc": {
            "0xed9d02e382b34818e88b88a309c7fe71e65f419d": {
              "balance": "1000000000000000000000000000"
            },
            "0xca843569e3427144cead5e4d5999a3d0ccf92b8e": {
              "balance": "1000000000000000000000000000"
            },
            "4cb6046ae395bb6b5f9febc7bdcae28489268725": {
              "balance": "1000000000000000000000000000"
            }
          },
          "coinbase": "0x0000000000000000000000000000000000000000",
          "config": {
            "homesteadBlock": 0,
            "byzantiumBlock": 0,
            "constantinopleBlock": 0,
            "chainId": 10,
            "eip150Block": 0,
            "eip155Block": 0,
            "eip150Hash": "0x0000000000000000000000000000000000000000000000000000000000000000",
            "eip158Block": 0,
            "maxCodeSize": 35,
            "isQuorum": true
          },
          "difficulty": "0x0",
          "extraData": "0x0000000000000000000000000000000000000000000000000000000000000000",
          "gasLimit": "0xE0000000",
          "mixhash": "0x00000000000000000000000000000000000000647572616c65787365646c6578",
          "nonce": "0x0",
          "parentHash": "0x0000000000000000000000000000000000000000000000000000000000000000",
          "timestamp": "0x00"
        }
      },
      {
        "input": {
          "address": "4cb6046ae395bb6b5f9febc7bdcae28489268725",
          "crypto": {
            "cipher": "aes-128-ctr",
            "ciphertext": "04c9b4c56b717d2f64714de8aa9112c182eccc4e8e578b4c6d89b1621a3cd7c7",
            "cipherparams": {
              "iv": "fca58569c4c864f9d9ac5953ee29f713"
            },
            "kdf": "scrypt",
            "kdfparams": {
              "dklen": 32,
              "n": 262144,
              "p": 1,
              "r": 8,
              "salt": "c2331c103e8a3321796fbaa79bcff301e22fa9b8cc4fb811ca0cbf96b48e697b"
            },
            "mac": "0656363e9828aa0f29215261c442169f33816156ce7d7ea795849c971a39fb7a"
          },
          "id": "3da32d09-f0b0-44a0-98ab-e9d03df7c952",
          "version": 3
        }
      }
    ],
    "identifier": 63845393
  },
  {
    "context": [
      "I am trying to eliminate the extraneous nesting of\n- \"ExprMap\": { \"data\": KEEP-THIS } }\n- \"ExprString\": { \"data\": KEEP-THIS } }\nto get\n\n{\n  \"Board: WEC\": {\n    \"noAddr\": \"11112aoa6NLYomYZro566XZVGEXyCDqeqDcp8Pzg81Ckuws6SexC99\",\n    \"shortDesc\": \"Wile E. Coyote for Board Member\",\n    \"yesAddr\": \"11112gUFvJR6JBDYJURETaWUBpEDa1EyjgRHFncEfQ4hGECnciPnhw\"\n  },\n  \"Board: DaD\": {\n    \"noAddr\": \"11112Cwtg2Bs4WUAYrXhL9xZXXSXr9Gn62Cty39RhUaBnqjrKkqwAZ\",\n    \"shortDesc\": \"Daffy Duck for Board Member\",\n    \"yesAddr\": \"1111TnFUN7eZBWXp3QQACQRRxpcS5uH5Bpf67vikWhA5e3F6ikAmU\"\n  }",
      "map_values( .ExprMap.data | map_values(.ExprString.data) )",
      "walk(if type == \"object\"\n     then if has(\"ExprMap\") then del(.ExprMap) + (.ExprMap.data | map_values(.ExprString.data)) else . end\n     else . end)",
      "def detype:\n  if type == \"object\"\n  then if has(\"ExprTuple\") then .ExprTuple.data | map(detype)\n       elif has(\"ExprList\") then .ExprList.data | map(detype)\n       elif has(\"ExprMap\") then .ExprMap.data | detype\n       elif has(\"ExprString\") then .ExprString.data\n       else . end\n  else . end;\nwalk(detype)"
    ],
    "utterance": "Remove nested ExprMap and ExprString.type and data layers to produce a flat mapping from each board name to its underlying address and description strings.",
    "expressions": [
      "map_values( .ExprMap.data | map_values(.ExprString.data) )",
      "walk(if type == \"object\" then if has(\"ExprMap\") then del(.ExprMap) + (.ExprMap.data | map_values(.ExprString.data)) else . end else . end)",
      "def detype: if type == \"object\" then if has(\"ExprTuple\") then .ExprTuple.data | map(detype) elif has(\"ExprList\") then .ExprList.data | map(detype) elif has(\"ExprMap\") then .ExprMap.data | detype elif has(\"ExprString\") then .ExprString.data else . end else . end; walk(detype)"
    ],
    "data": [
      {
        "input": {
          "Board: WEC": {
            "ExprMap": {
              "data": {
                "noAddr": {
                  "ExprString": {
                    "data": "11112aoa6NLYomYZro566XZVGEXyCDqeqDcp8Pzg81Ckuws6SexC99"
                  }
                },
                "shortDesc": {
                  "ExprString": {
                    "data": "Wile E. Coyote for Board Member"
                  }
                },
                "yesAddr": {
                  "ExprString": {
                    "data": "11112gUFvJR6JBDYJURETaWUBpEDa1EyjgRHFncEfQ4hGECnciPnhw"
                  }
                }
              }
            }
          },
          "Board: DaD": {
            "ExprMap": {
              "data": {
                "noAddr": {
                  "ExprString": {
                    "data": "11112Cwtg2Bs4WUAYrXhL9xZXXSXr9Gn62Cty39RhUaBnqjrKkqwAZ"
                  }
                },
                "shortDesc": {
                  "ExprString": {
                    "data": "Daffy Duck for Board Member"
                  }
                },
                "yesAddr": {
                  "ExprString": {
                    "data": "1111TnFUN7eZBWXp3QQACQRRxpcS5uH5Bpf67vikWhA5e3F6ikAmU"
                  }
                }
              }
            }
          }
        },
        "output": {
          "Board: WEC": {
            "noAddr": "11112aoa6NLYomYZro566XZVGEXyCDqeqDcp8Pzg81Ckuws6SexC99",
            "shortDesc": "Wile E. Coyote for Board Member",
            "yesAddr": "11112gUFvJR6JBDYJURETaWUBpEDa1EyjgRHFncEfQ4hGECnciPnhw"
          },
          "Board: DaD": {
            "noAddr": "11112Cwtg2Bs4WUAYrXhL9xZXXSXr9Gn62Cty39RhUaBnqjrKkqwAZ",
            "shortDesc": "Daffy Duck for Board Member",
            "yesAddr": "1111TnFUN7eZBWXp3QQACQRRxpcS5uH5Bpf67vikWhA5e3F6ikAmU"
          }
        }
      }
    ],
    "identifier": 63871422
  },
  {
    "context": [
      "What is the correct way to get this result?",
      "I just cannot find the right syntax.",
      "jq -r '.[] | .batch_id |= lpad(\"\\(.batch_id)\";8;\"0\")' xyz.json;",
      "jq: error (at /dev/shm/xyz.json:14): Cannot index number with string \"batch_id\"",
      "map(.batch_id |= lpad(8; \"0\"))"
    ],
    "utterance": "Pad each batch_id value in the input array with leading zeroes to a fixed width of 8 characters, keeping all other data unchanged.",
    "expressions": [
      "def lpad($len; $fill): tostring | ($len - length) as $l | ($fill * $l)[:$l] + .; map(.batch_id |= lpad(8; \"0\"))"
    ],
    "data": [
      {
        "input": [
          {
            "batch_id": 526,
            "aCods": [
              "IBDD879"
            ]
          },
          {
            "batch_id": 357,
            "aCods": [
              "IBDD212"
            ]
          }
        ],
        "output": [
          {
            "batch_id": "00000526",
            "aCods": [
              "IBDD879"
            ]
          },
          {
            "batch_id": "00000357",
            "aCods": [
              "IBDD212"
            ]
          }
        ]
      }
    ],
    "identifier": 63906770
  },
  {
    "context": [
      "When Header.Tenant ===\"TenantX\" and Body.values[].name ==\"Attribute1\" \nthen\ndisplay the value of \"id\"  \nin the same block where \"Attribute1\" is",
      "then select the `id` of the objects where `name` matches your string:",
      ".[].Body.values[] | select(.name == \"Attribute1\").id"
    ],
    "utterance": "Find the id where Header.Tenant is \"TenantX\" and Body.values[].name is \"Attribute1\".",
    "expressions": [
      ".[] | select(.Header.Tenant == \"TenantX\") | .Body.values[] | select(.name == \"Attribute1\").id"
    ],
    "data": [
      {
        "input": [
          {
            "Header": {
              "Tenant": "TenantX",
              "Rcode": 200
            },
            "Body": {
              "values": [
                {
                  "id": "aaaa0001-0a0a-0b0b-0a95-6625bef115e5",
                  "name": "Attribute1"
                },
                {
                  "id": "aaaa0001-0a0a-0b0b-9926-f5dc47d312dd",
                  "name": "Attribute2"
                },
                {
                  "id": "aaaa0001-0a0a-0b0b-aea9-6b39641a0695",
                  "name": "Attribute3"
                },
                {
                  "id": "aaaa0001-0a0a-0b0b-a62b-5b26838eeca7",
                  "name": "Attribute4"
                }
              ]
            }
          }
        ],
        "output": "aaaa0001-0a0a-0b0b-0a95-6625bef115e5"
      }
    ],
    "identifier": 63903553
  },
  {
    "context": [
      "Assuming `input.json` file is:\r\n\r\n```json\r\n[{\"Russia\": 1073849}]\r\n[{\"Spain\": 593730}]\r\n[{\"France\": 387252}]\r\n[{ \"UK\": 371125}]\r\n```\r\n\r\nThen this:\r\n\r\n```lang-none\r\njq -s 'reduce .[] as $x ([]; . + $x)' input.json\r\n```\r\n\r\nreturns:\r\n\r\n```json\r\n[\r\n  {\r\n    \"Russia\": 1073849\r\n  },\r\n  {\r\n    \"Spain\": 593730\r\n  },\r\n  {\r\n    \"France\": 387252\r\n  },\r\n  {\r\n    \"UK\": 371125\r\n  }\r\n]\r\n```",
      "This can be simplified even further with:\r\n\r\n```lang-none\r\njq -s 'add' input.json\r\n```"
    ],
    "utterance": "Merge multiple top-level arrays of country:cases objects into a single array with all objects.",
    "expressions": [
      "jq -s 'reduce .[] as $x ([]; . + $x)' input.json",
      "jq -s 'add' input.json"
    ],
    "data": [
      {
        "input": [
          [
            {
              "Russia": 1073849
            }
          ],
          [
            {
              "Spain": 593730
            }
          ],
          [
            {
              "France": 387252
            }
          ],
          [
            {
              "UK": 371125
            }
          ]
        ],
        "output": [
          {
            "Russia": 1073849
          },
          {
            "Spain": 593730
          },
          {
            "France": 387252
          },
          {
            "UK": 371125
          }
        ]
      }
    ],
    "identifier": 63908137
  },
  {
    "context": [
      "I have graph data in JSON and would like to massage it a bit so that:\r\n\r\n    {\"1\": [1, 2, 3, 4],\r\n    \"2\": [3, 4, 7]}\r\n\r\nBecomes\r\n\r\n    [1, 1]\r\n    [1, 2]\r\n    [1, 3]\r\n    [1, 4]\r\n    [2, 3]\r\n    [2, 4]\r\n    [2, 7]",
      "You can use the following :\r\n\r\n    to_entries | map([[.key|tonumber],.value] | combinations) | .[]",
      "keys_unsorted[] as $k\r\n| .[$k][] as $v\r\n| [$k|tonumber] + [$v]"
    ],
    "utterance": "Transform a dictionary of node neighbors to an array of [source, target] pairs, where each source key is paired with each element in its corresponding value array.",
    "expressions": [
      "to_entries | map([[.key|tonumber],.value] | combinations) | .[]",
      "keys_unsorted[] as $k | .[$k][] as $v | [$k|tonumber] + [$v]"
    ],
    "data": [
      {
        "input": {
          "1": [
            1,
            2,
            3,
            4
          ],
          "2": [
            3,
            4,
            7
          ]
        },
        "output": [
          [
            1,
            1
          ],
          [
            1,
            2
          ],
          [
            1,
            3
          ],
          [
            1,
            4
          ],
          [
            2,
            3
          ],
          [
            2,
            4
          ],
          [
            2,
            7
          ]
        ]
      }
    ],
    "identifier": 63920424
  },
  {
    "context": [
      "It works well except for one thing. It doesn't seem to handle having that value not exist. It only returns when all values exist.",
      "having this value not return at all would suffice",
      "You can probably achieve what you need using the alternative operator //.",
      "$ jq '.[] | {aa: .a, bb: (.b[].c // \"\")}' test.json # attempt 2",
      "Deleting the nonexistent entries can be done multiple ways, for example:",
      "$ jq '.[] \n  | {aa: .a, bb: (.b[].c // null)} \n  | if .bb == null then del(.bb) else . end\n' test.json"
    ],
    "utterance": "Extract SecurityGroups with fields name, groupid, ips, and sourcegroup, using an empty string or omitting the field if ips or sourcegroup do not exist.",
    "expressions": [
      ".SecurityGroups[] | {name: .GroupName, groupid: .GroupId, ips: (.IpPermissions[].IpRanges[].CidrIp // \"\"), sourcegroup: (.IpPermissions[].UserIdGroupPairs[].GroupId // \"\")}",
      ".SecurityGroups[] | {name: .GroupName, groupid: .GroupId, ips: (.IpPermissions[].IpRanges[].CidrIp // null), sourcegroup: (.IpPermissions[].UserIdGroupPairs[].GroupId // null)} | with_entries(select(.value != null))"
    ],
    "data": [
      {
        "input": {
          "SecurityGroups": [
            {
              "GroupName": "group1",
              "IpPermissions": [
                {
                  "IpRanges": [
                    {
                      "CidrIp": "10.0.0.0/8"
                    }
                  ],
                  "UserIdGroupPairs": []
                }
              ],
              "GroupId": "sg-012345"
            },
            {
              "GroupName": "group2",
              "IpPermissions": [
                {
                  "IpRanges": [],
                  "UserIdGroupPairs": [
                    {
                      "GroupId": "sg-abcd"
                    }
                  ]
                }
              ],
              "GroupId": "sg-06789"
            },
            {
              "GroupName": "group3",
              "IpPermissions": [
                {
                  "IpRanges": [
                    {
                      "CidrIp": "192.0.0.0/8"
                    }
                  ],
                  "UserIdGroupPairs": [
                    {
                      "GroupId": "sg-xyz"
                    }
                  ]
                }
              ],
              "GroupId": "sg-xyz"
            }
          ]
        },
        "output": [
          {
            "name": "group1",
            "groupid": "sg-012345",
            "ips": "10.0.0.0/8",
            "sourcegroup": ""
          },
          {
            "name": "group2",
            "groupid": "sg-06789",
            "ips": "",
            "sourcegroup": "sg-abcd"
          },
          {
            "name": "group3",
            "groupid": "sg-xyz",
            "ips": "192.0.0.0/8",
            "sourcegroup": "sg-xyz"
          }
        ]
      }
    ],
    "identifier": 63907698
  },
  {
    "context": [
      "I want to group arrays based on `\"name\"` and push them under new `\"Arrays\"` object. So the result should look like the following:",
      "[ group_by(.name)[] | add ] | map( { name: .name, Arrays: del(.name) } )"
    ],
    "utterance": "Group objects by their name field and combine all remaining key-value pairs for each group under an Arrays object.",
    "expressions": [
      "[ group_by(.name)[] | add ] | map( { name: .name, Arrays: del(.name) } )"
    ],
    "data": [
      {
        "input": [
          {
            "name": "T1",
            "R10": [
              "A",
              "B"
            ]
          },
          {
            "name": "T1",
            "M20": [
              "C"
            ]
          },
          {
            "name": "A1",
            "C20": [
              "A",
              "B"
            ]
          },
          {
            "name": "B1",
            "V30": [
              "3"
            ]
          },
          {
            "name": "C1",
            "X50": [
              "1"
            ]
          }
        ],
        "output": [
          {
            "name": "A1",
            "Arrays": {
              "C20": [
                "A",
                "B"
              ]
            }
          },
          {
            "name": "B1",
            "Arrays": {
              "V30": [
                "3"
              ]
            }
          },
          {
            "name": "C1",
            "Arrays": {
              "X50": [
                "1"
              ]
            }
          },
          {
            "name": "T1",
            "Arrays": {
              "R10": [
                "A",
                "B"
              ],
              "M20": [
                "C"
              ]
            }
          }
        ]
      }
    ],
    "identifier": 63922373
  },
  {
    "context": [
      "My task is the following: for each ``\"city\"`` values, which are known, get the names of arrays and for each array, get its contents printed/displayed. Names of cities and arrays are unique, the content of arrays - are not.",
      "The result should look like the following:",
      "Now working on Seattle",
      "Seattle has the following arrays: ",
      "array10",
      "array11",
      "Content of the array10",
      "1",
      "2",
      "Content of the array11",
      "3",
      "Using the -r command-line option, the following program produces the output as shown below:",
      "group_by(.city)[]",
      "| .[0].city as $city",
      "| map(keys_unsorted[] | select(test(\"^array\"))) as $arrays",
      "| \"Now working on \\($city)\",",
      "  \"\\($city) has the following arrays:\",",
      "  $arrays[],",
      "  (.[] | to_entries[] | select(.key | test(\"^array\"))",
      "   | \"Content of the \\(.key)\", .value[])"
    ],
    "utterance": "For each city, list the names of array fields, and for each array, display its contents in a structured message.",
    "expressions": [
      "group_by(.city)[]\n| .[0].city as $city\n| map(keys_unsorted[] | select(test(\"^array\"))) as $arrays\n| \"Now working on \\($city)\",\n  \"\\($city) has the following arrays:\",\n  $arrays[],\n  (.[] | to_entries[] | select(.key | test(\"^array\"))\n   | \"Content of the \\(.key)\", .value[])"
    ],
    "data": [
      {
        "input": [
          {
            "city": "Seattle",
            "array10": [
              "1",
              "2"
            ]
          },
          {
            "city": "Seattle",
            "array11": [
              "3"
            ]
          },
          {
            "city": "Chicago",
            "array20": [
              "1",
              "2"
            ]
          },
          {
            "city": "Denver",
            "array30": [
              "3"
            ]
          },
          {
            "city": "Reno",
            "array50": [
              "1"
            ]
          }
        ],
        "output": [
          "Now working on Chicago",
          "Chicago has the following arrays:",
          "array20",
          "Content of the array20",
          "1",
          "2",
          "Now working on Denver",
          "Denver has the following arrays:",
          "array30",
          "Content of the array30",
          "3",
          "Now working on Reno",
          "Reno has the following arrays:",
          "array50",
          "Content of the array50",
          "1",
          "Now working on Seattle",
          "Seattle has the following arrays:",
          "array10",
          "array11",
          "Content of the array10",
          "1",
          "2",
          "Content of the array11",
          "3"
        ]
      }
    ],
    "identifier": 63920277
  },
  {
    "context": [
      "jq -r --arg k \"foo\" --arg v \"bar\"  '.newField += {$k:$v}' myfile",
      "jq: error: syntax error, unexpected ':', expecting '}' (Unix shell quoting issues?) at <top-level>, line 1:",
      ".newField += {$k:$v}",
      "As the error message suggests, put parentheses around the key:",
      "jq -r --arg k \"foo\" --arg v \"bar\"  '.newField += {($k):$v}' myfile",
      "jq requires keys given by expressions (i.e. not literal strings) to be parenthesized ([noted in the manual](https://stedolan.github.io/jq/manual/v1.6/#ObjectConstruction:{})).",
      "$ jq -r --arg foo \"bar\"  '.newField += {$foo}' myfile",
      "\"newField\": {",
      "    \"foo\": \"bar\"",
      "}"
    ],
    "utterance": "Add a new key-value pair to the object at .newField, where the key and value come from shell arguments.",
    "expressions": [
      ".newField += {($k): $v}",
      ".newField += {$foo}"
    ],
    "identifier": 63954278
  },
  {
    "context": [
      "I\u2019m trying to filter the following json object to get the id which doesn\u2019t have a domain value which is either \"moderator\" or \"owner\" using jq in bash script.",
      "The problem is my third domain value is random and not predetermined. How do I filter it?",
      "$ jq '.data[] | select(.domain != \"moderator\" and .domain != \"owner\")' input.json",
      "If you just want the id value and not the entire object, add `| .id` to the end of the jq filter.",
      "cat text.json | jq '.data[] | select((.domain != \"moderator\") and (.domain != \"owner\"))'"
    ],
    "utterance": "Return the id for every object where domain is not equal to moderator and not equal to owner.",
    "expressions": [
      ".data[] | select(.domain != \"moderator\" and .domain != \"owner\") | .id"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": 1,
              "domain": "moderator"
            },
            {
              "id": 2,
              "domain": "owner"
            },
            {
              "id": 3,
              "domain": "34b5756175a848f7a1395e1a19e10602"
            }
          ]
        },
        "output": 3
      }
    ],
    "identifier": 63950396
  },
  {
    "context": [
      "I need to find out for the particular ``\"name/Property\"`` key/value how many different corresponding ``\"id\"`` and ``\"Tenant\"`` exist and group them by the value of ``\"id\"`` instead.",
      "The result should look like the following: \n\n```\n[\n    {\n        \"name\": \"Property1\",\n        \"ca95\": [\n            \"Tenant1\",\n            \"Tenant2\"\n        ]\n    },\n    {\n        \"name\": \"Property2\",\n        \"b126\": [\n            \"Tenant1\"\n        ]\n    },\n    {\n        \"name\": \"Property3\",\n        \"aec0\": [\n            \"Tenant1\"\n        ]\n    },\n    {\n        \"name\": \"Property4\",\n        \"a62b\": [\n            \"Tenant1\"\n        ]\n    },\n    {\n        \"name\": \"Property4\",\n        \"b4cd\": [\n            \"Tenant2\"\n        ]\n    }\n]\n```",
      "It can be done quite easily with just `group_by` and `map`:\n```\nmap(.Header.Tenant as $tenant\n    | .Body.values[] | {name, id, tenant: $tenant})\n| group_by(.name)\n| map(group_by(.id))\n| map( .[] |  (.[0] | { name }) + { (.[0].id): map(.tenant) })\n```",
      "The solution can now be written in a straightforward manner without further recourse to `reduce`:\n```\n[ GROUPS_BY(.[]\n            | .Header.Tenant as $tenant\n            | .Body.values[] | {name, id, tenant: $tenant};\n            {name,id}) \n  | (.[0] | { name }) + { (.[0].id): map(.tenant) } ]\n```"
    ],
    "utterance": "Produce an array in which each entry contains a property name and, for each unique id associated with that name, a key listing all matching Tenants.",
    "expressions": [
      "map(.Header.Tenant as $tenant | .Body.values[] | {name, id, tenant: $tenant})\n| group_by(.name)\n| map(group_by(.id))\n| map( .[] |  (.[0] | { name }) + { (.[0].id): map(.tenant) })",
      "[ GROUPS_BY(.[]\n            | .Header.Tenant as $tenant\n            | .Body.values[] | {name, id, tenant: $tenant};\n            {name,id}) \n  | (.[0] | { name }) + { (.[0].id): map(.tenant) } ]"
    ],
    "data": [
      {
        "input": [
          {
            "Header": {
              "Tenant": "Tenant1"
            },
            "Body": {
              "values": [
                {
                  "id": "ca95",
                  "name": "Property1"
                },
                {
                  "id": "b126",
                  "name": "Property2"
                },
                {
                  "id": "aec0",
                  "name": "Property3"
                },
                {
                  "id": "a62b",
                  "name": "Property4"
                }
              ]
            }
          },
          {
            "Header": {
              "Tenant": "Tenant2"
            },
            "Body": {
              "values": [
                {
                  "id": "ca95",
                  "name": "Property1"
                },
                {
                  "id": "b4cd",
                  "name": "Property4"
                }
              ]
            }
          }
        ],
        "output": [
          {
            "name": "Property1",
            "ca95": [
              "Tenant1",
              "Tenant2"
            ]
          },
          {
            "name": "Property2",
            "b126": [
              "Tenant1"
            ]
          },
          {
            "name": "Property3",
            "aec0": [
              "Tenant1"
            ]
          },
          {
            "name": "Property4",
            "a62b": [
              "Tenant1"
            ]
          },
          {
            "name": "Property4",
            "b4cd": [
              "Tenant2"
            ]
          }
        ]
      }
    ],
    "identifier": 63909759
  },
  {
    "context": [
      "My task - to select all *unique, non-empty* values of the ``\"webServerName\"`` key which have the web URL form, ending at ``:443`` and display all these values without double quotes one on each line.",
      "P.S. One additional requirement - exclude values that have certain patterns in the `url`. So for example the `url` contains ``server-internal`` in the `url`, then ``www.server-internal.example.com:443`` or ``server-internal.b.example.com:443`` should be filtered out.",
      "You could very simply use the recursive descent on the `webServerName` field, ignore the empty ones and select ones ending with `:443` using the `endswith/1` function which is much straightforward than using a regex based approach.",
      "[ .. | .webServerName? | select(. != null and endswith(\":443\")) ] | unique[]",
      "map(.Body[].webServerName | select(. != null and endswith(\":443\") ) ) | unique[]",
      "map( .Body[].webServerName | \n  select( ( . != null and endswith(\":443\") ) and \n    ( test(\"server-internal\") | not ) ) ) | \nunique[]"
    ],
    "utterance": "Return all unique, non-empty values of the webServerName field that end with :443 and do not contain 'server-internal', displaying each on a new line and without quotes.",
    "expressions": [
      "[ .. | .webServerName? | select(. != null and endswith(\":443\") and (test(\"server-internal\") | not )) ] | unique[]",
      "map(.Body[].webServerName | select(. != null and endswith(\":443\") and (test(\"server-internal\") | not )) ) | unique[]"
    ],
    "data": [
      {
        "input": [
          {
            "Body": [
              {
                "agentTechnologyType": "JAVA",
                "webApplicationId": "/solr",
                "webServerName": "localhost"
              },
              {
                "agentTechnologyType": "JAVA",
                "contextRoot": "/backoffice",
                "webApplicationId": "backoffice",
                "webServerName": "Catalina/localhost"
              },
              {
                "agentTechnologyType": "JAVA",
                "discoveredName": "ImpExImportJob",
                "displayName": "ImpExImportJob",
                "entityId": "SERVICE-D2B53C681D503292",
                "toRelationships": {
                  "calls": [
                    "SERVICE-A744C713BB5D832B"
                  ]
                }
              },
              {
                "agentTechnologyType": "JAVA",
                "discoveredName": "CronJobs"
              },
              {
                "agentTechnologyType": "APACHE",
                "contextRoot": "/",
                "discoveredName": "www.example.com:443",
                "displayName": "www.example.com:443",
                "serviceType": "WebRequest",
                "webServerName": "www.example.com:443"
              },
              {
                "agentTechnologyType": "APACHE",
                "contextRoot": "/service",
                "discoveredName": "www.example.com:443",
                "displayName": "www.example.com:443",
                "entityId": "SERVICE-96405085FB29CC50",
                "webServerName": "www.example.com:443"
              },
              {
                "agentTechnologyType": "APACHE",
                "contextRoot": "/nodes",
                "discoveredName": "www.exampleA.com:443",
                "displayName": "www.exampleA.com:443",
                "entityId": "SERVICE-15578BCF4A5FF4D5",
                "toRelationships": {},
                "webServerName": "www.exampleA.com:443"
              },
              {
                "agentTechnologyType": "APACHE",
                "contextRoot": "/",
                "discoveredName": "www.example.com:80",
                "displayName": "www.example.com:80",
                "entityId": "SERVICE-F9193C47A131E506",
                "toRelationships": {},
                "webServerName": "www.example.com:80"
              }
            ]
          }
        ],
        "output": [
          "www.example.com:443",
          "www.exampleA.com:443"
        ]
      }
    ],
    "identifier": 63938687
  },
  {
    "context": [
      "I have this output from a pipe ... { \"pipelineName\": \"pipelineName-AAAAQ6UFM\", ... }",
      "I am trying to write a json like this ... { \"pipelineName\": \"pipelineName-AAAAQ6UFM\", \"stageName\": \"Approval\", \"actionName\": \"Approval\", \"token\": \"aaaa-aaaa-4316-a95f-2efc51d05761\", \"result\": { \"status\": \"Approved\", \"summary\": \"\" } }",
      "You can use just `jq` to create the json:",
      "jq ' .stageName  = .stageStates[0].stageName\n   | .actionName = .stageStates[0].actionStates[0].actionName\n   | .token      = .stageStates[0].actionStates[0].latestExecution.token\n   | .result     = { \"status\": \"Approved\", \"summary\": \"\" }\n   | del(.stageStates, .pipelineVersion)\n   ' file.json",
      "Based on your `select(.stageName == \"Approval\")`, it would appear that you are attempting to parameterize by the \"stageName\" ...",
      "\"Approval\" as $stage\n| { pipelineName, stageName: $stage, actionName: $stage }\n  + (.stageStates[] \n     | select(.stageName == $stage).actionStates[]\n     | select(.actionName == $stage)\n     | {token: .latestExecution.token, result: {status: \"Approved\", summary: \"\"}})"
    ],
    "utterance": "Produce an object with pipelineName, stageName, actionName, token, and result fields, where stageName and actionName are 'Approval', and result is {status: 'Approved', summary: ''}.",
    "expressions": [
      ".stageName  = .stageStates[0].stageName\n| .actionName = .stageStates[0].actionStates[0].actionName\n| .token      = .stageStates[0].actionStates[0].latestExecution.token\n| .result     = { \"status\": \"Approved\", \"summary\": \"\" }\n| del(.stageStates, .pipelineVersion)",
      "\"Approval\" as $stage\n| { pipelineName, stageName: $stage, actionName: $stage }\n  + (.stageStates[] \n     | select(.stageName == $stage).actionStates[]\n     | select(.actionName == $stage)\n     | {token: .latestExecution.token, result: {status: \"Approved\", summary: \"\"}})"
    ],
    "data": [
      {
        "input": {
          "pipelineName": "pipelineName-AAAAQ6UFM",
          "pipelineVersion": 2,
          "stageStates": [
            {
              "stageName": "Approval",
              "inboundTransitionState": {
                "enabled": true
              },
              "actionStates": [
                {
                  "actionName": "Approval",
                  "latestExecution": {
                    "status": "InProgress",
                    "token": "aaaa-aaaa-4316-a95f-2efc51d05761"
                  }
                }
              ],
              "latestExecution": {
                "pipelineExecutionId": "fc73f4cb-c5a9-44a8-8fc1-d7e50259f485",
                "status": "InProgress"
              }
            }
          ]
        },
        "output": {
          "pipelineName": "pipelineName-AAAAQ6UFM",
          "stageName": "Approval",
          "actionName": "Approval",
          "token": "aaaa-aaaa-4316-a95f-2efc51d05761",
          "result": {
            "status": "Approved",
            "summary": ""
          }
        }
      }
    ],
    "identifier": 63941787
  },
  {
    "context": [
      "I have a verge large file, 24 GB which consists an array of 22M JSON objects. I have to do some manipulation for each JSON object and write into another file.",
      "the output contains JSON objects separated by new line and there is no parent array. ... I want to convert it into original structure with an array consists of objects separated by comma without affecting memory",
      "Another possibility, again based on the above assumption, might be to combine the two calls to jq into one:",
      "< data.json jq -cn --stream '[fromstream(1|truncate_stream(inputs)) | if has (\"middleName\") then .sortableMiddleName=.middleName else . end | if has(\"middleName\") then .middleName=[.middleName] else . end ]'",
      "There should be no need to invoke jq twice, but because the output array is going to be so large, your best bet is probably to convert your stream of objects to a JSON array in a funky way",
      "echo '['",
      "< data.json jq -nr --stream 'fromstream(1|truncate_stream(inputs)) | (if has (\"middleName\") then .sortableMiddleName=.middleName else . end | if has(\"middleName\") then .middleName=[.middleName] else . end), \",\"' | sed '$d'",
      "echo ']'"
    ],
    "utterance": "Apply transformations to each object so that if it has a \"middleName\" field, add a \"sortableMiddleName\" field with the same value, and replace \"middleName\" with an array containing its value; output the results as a single array of objects, preserving stream processing for large input.",
    "expressions": [
      "< data.json jq -cn --stream '[fromstream(1|truncate_stream(inputs)) | if has (\"middleName\") then .sortableMiddleName=.middleName else . end | if has(\"middleName\") then .middleName=[.middleName] else . end ]'",
      "echo '['",
      "< data.json jq -nr --stream 'fromstream(1|truncate_stream(inputs)) | (if has (\"middleName\") then .sortableMiddleName=.middleName else . end | if has(\"middleName\") then .middleName=[.middleName] else . end), \",\"' | sed '$d'",
      "echo ']'"
    ],
    "identifier": 63989426
  },
  {
    "context": [
      "My need is to match the value of `descriptionId` from *file2* found in *file1*; But want to produce a final out \u2014even if it is *file3*, that replaces that key value in a way to ends up into something like this:",
      "jq --argfile file1 file1.json -f program.jq file2.json",
      "($file1 | INDEX(.value[]; .id) | map_values(.description)) as $dict\n| map(.description = $dict[.descriptionId] | del(.descriptionId))"
    ],
    "utterance": "Replace the descriptionId field in each item with the corresponding description from another file based on matching id values.",
    "expressions": [
      "($file1 | INDEX(.value[]; .id) | map_values(.description)) as $dict | map(.description = $dict[.descriptionId] | del(.descriptionId))"
    ],
    "data": [
      {
        "input": {
          "file1.json": {
            "value": [
              {
                "description": "foo bar",
                "id": "111111-0000-0000-1111-foobar"
              }
            ]
          },
          "file2.json": [
            {
              "businessPhones": [
                "555-505-4321"
              ],
              "displayName": "Abc",
              "givenName": "abc",
              "id": "000000-1111-1111-0000-abcabc",
              "descriptionId": "111111-0000-0000-1111-foobar"
            }
          ]
        },
        "output": [
          {
            "businessPhones": [
              "555-505-4321"
            ],
            "displayName": "Abc",
            "givenName": "abc",
            "id": "000000-1111-1111-0000-abcabc",
            "description": "foo bar"
          }
        ]
      }
    ],
    "identifier": 63948803
  },
  {
    "context": [
      "Trying to convert the json data below into csv, using jq and or awk or python or perl or anything from Linux shell.",
      "The csv output should look like this:",
      "Earth,6,ONLINE",
      "Earth,8,EXIST",
      "Earth,1,GIVEN",
      "...etc",
      "The following will produce the output as shown if jq is invoked with the -r option:",
      ".inventory[]\n| .profile as $profile\n| .invState[]\n| [$profile] + [.count, .Status]\n| join(\",\")",
      "If CSV output is desired, then it might be better to replace the join in the last line by @csv.",
      "The following is equivalent to the above:\n.inventory[]\n| [.profile] + (.invState[] | [.count, .Status])\n| join(\",\")",
      "If the order of the \"count\" and \"Status\" keys is fixed, you could get away with:\n.inventory[] \n| [.profile] + (.invState[] | [.[]])\n| join(\",\")",
      "The following invocation of jq should do the trick:",
      "jq --raw-output '.inventory[] | .profile as $p | .invState[] | \"\\($p),\\(.count),\\(.Status)\"' input.json"
    ],
    "utterance": "Produce CSV rows with the profile, count, and Status fields for each invState within inventory.",
    "expressions": [
      ".inventory[] | .profile as $profile | .invState[] | [$profile] + [.count, .Status] | join(\",\")",
      ".inventory[] | [.profile] + (.invState[] | [.count, .Status]) | join(\",\")",
      ".inventory[] | [.profile] + (.invState[] | [.[]]) | join(\",\")",
      ".inventory[] | .profile as $p | .invState[] | \"\\($p),\\(.count),\\(.Status)\""
    ],
    "data": [
      {
        "input": {
          "inventory": [
            {
              "profile": "Earth",
              "invState": [
                {
                  "count": 6,
                  "Status": "ONLINE"
                },
                {
                  "count": 8,
                  "Status": "EXIST"
                },
                {
                  "count": 1,
                  "Status": "GIVEN"
                },
                {
                  "count": 4,
                  "Status": "ERROR"
                },
                {
                  "count": 49,
                  "Status": "INSTOCK"
                },
                {
                  "count": 389,
                  "Status": "RELEASED"
                },
                {
                  "count": 68,
                  "Status": "DELETED"
                },
                {
                  "count": 280,
                  "Status": "CONNECTED"
                },
                {
                  "count": 1,
                  "Status": "UNINSTOCK"
                }
              ]
            },
            {
              "profile": "Mars",
              "invState": [
                {
                  "count": 7,
                  "Status": "EXIST"
                },
                {
                  "count": 20,
                  "Status": "INSTOCK"
                },
                {
                  "count": 110,
                  "Status": "RELEASED"
                },
                {
                  "count": 16,
                  "Status": "DELETED"
                },
                {
                  "count": 41,
                  "Status": "CONNECTED"
                },
                {
                  "count": 1,
                  "Status": "UNINSTOCK"
                }
              ]
            },
            {
              "profile": "Mercury",
              "invState": [
                {
                  "count": 4,
                  "Status": "EXIST"
                },
                {
                  "count": 1224,
                  "Status": "INSTOCK"
                },
                {
                  "count": 3,
                  "Status": "CONNECTED"
                },
                {
                  "count": 18,
                  "Status": "RELEASED"
                },
                {
                  "count": 5,
                  "Status": "DELETED"
                }
              ]
            }
          ]
        },
        "output": [
          "Earth,6,ONLINE",
          "Earth,8,EXIST",
          "Earth,1,GIVEN",
          "Earth,4,ERROR",
          "Earth,49,INSTOCK",
          "Earth,389,RELEASED",
          "Earth,68,DELETED",
          "Earth,280,CONNECTED",
          "Earth,1,UNINSTOCK",
          "Mars,7,EXIST",
          "Mars,20,INSTOCK",
          "Mars,110,RELEASED",
          "Mars,16,DELETED",
          "Mars,41,CONNECTED",
          "Mars,1,UNINSTOCK",
          "Mercury,4,EXIST",
          "Mercury,1224,INSTOCK",
          "Mercury,3,CONNECTED",
          "Mercury,18,RELEASED",
          "Mercury,5,DELETED"
        ]
      }
    ],
    "identifier": 63931452
  },
  {
    "context": [
      "jq --slurpfile loc \"loc.json\" \\\n        --arg URL \"$1\" \\\n        '.locations|=$loc[] |\n        .name=$URL |\n    .script.events[].url=$URL | \n    .script.events[].description=\"Loading of URL \\\"\" +$URL + \"\\\"\"' \\\n        \"tmpl.json\" >\"$1-temp.json\"",
      "jq --slurpfile loc \"loc.json\" \\\n     --argjson tmpl \"$(<tmpl.json)\" \\\n     -c -Rr  '\n    ($tmpl | .locations|=$loc[]) as $tmpl_with_loc |\n    . as $URL |\n    ($tmpl_with_loc |\n     .name=$URL |\n     .script.events[].url=$URL | \n     .script.events[].description=\"Loading of URL \\\"\\($URL)\\\"\" ) |\n    \"\\($URL)\\t\\(. | tojson)\"\n  ' < <(printf '%s\\n' \"${URL_list[@]}\")"
    ],
    "utterance": "For each value in a URL list, update the template so that .locations is set to the values from loc.json, .name and every .script.events[].url are set to the current URL, and .script.events[].description is set to 'Loading of URL \"<URL>\"'.",
    "expressions": [
      "jq --slurpfile loc \"loc.json\" \\\n     --argjson tmpl \"$(<tmpl.json)\" \\\n     -c -Rr  '\n    ($tmpl | .locations|=$loc[]) as $tmpl_with_loc |\n    . as $URL |\n    ($tmpl_with_loc |\n     .name=$URL |\n     .script.events[].url=$URL | \n     .script.events[].description=\"Loading of URL \\\"\\($URL)\\\"\" ) |\n    \"\\($URL)\\t\\(. | tojson)\"\n  ' < <(printf '%s\\n' \"${URL_list[@]}\")"
    ],
    "data": [
      {
        "input": {
          "tmpl.json": {
            "locations": [],
            "name": "",
            "script": {
              "events": [
                {
                  "description": "",
                  "type": "navigate",
                  "url": "",
                  "wait": {
                    "waitFor": "page_complete"
                  }
                }
              ],
              "version": "1.0"
            },
            "type": "BROWSER"
          },
          "loc.json": [
            "LOCATION-577B",
            "LOCATION-D7FF",
            "LOCATION-8BE4",
            "LOCATION-0CE9"
          ],
          "URL_list": [
            "example1.com",
            "example2.com"
          ]
        },
        "output": [
          "example1.com\t{\"locations\":[\"LOCATION-577B\",\"LOCATION-D7FF\",\"LOCATION-8BE4\",\"LOCATION-0CE9\"],\"name\":\"example1.com\",\"script\":{\"events\":[{\"description\":\"Loading of URL \\\"example1.com\\\"\",\"type\":\"navigate\",\"url\":\"example1.com\",\"wait\":{\"waitFor\":\"page_complete\"}}],\"version\":\"1.0\"},\"type\":\"BROWSER\"}",
          "example2.com\t{\"locations\":[\"LOCATION-577B\",\"LOCATION-D7FF\",\"LOCATION-8BE4\",\"LOCATION-0CE9\"],\"name\":\"example2.com\",\"script\":{\"events\":[{\"description\":\"Loading of URL \\\"example2.com\\\"\",\"type\":\"navigate\",\"url\":\"example2.com\",\"wait\":{\"waitFor\":\"page_complete\"}}],\"version\":\"1.0\"},\"type\":\"BROWSER\"}"
        ]
      }
    ],
    "identifier": 63977910
  }
]