[
  {
    "context": [
      "I\u2019d like to get the output in the format of\n\n{\n    \"abc\": [ 34, 45 ],\n    \"def\": [ 25 ]\n}",
      "Here is one way to do it.\n\n    jq 'reduce .[] as $i ({}; .[$i.id] += ($i|[.time]))'",
      "A functional (`reduce`-free) approach using only jq builtins:\n\ngroup_by(.id)\n| map( {(.[0]|.id): (map([.time]) | add)} )"
    ],
    "utterance": "Group objects by id and create an object mapping each id to an array of its corresponding time values.",
    "expressions": [
      "reduce .[] as $i ({}; .[$i.id] += ($i|[.time]))"
    ],
    "data": [
      {
        "input": [
          {
            "id": "abc",
            "time": 34
          },
          {
            "id": "def",
            "time": 25
          },
          {
            "id": "abc",
            "time": 45
          }
        ],
        "output": {
          "abc": [
            34,
            45
          ],
          "def": [
            25
          ]
        }
      }
    ],
    "identifier": 55244522
  },
  {
    "context": [
      "in `input_dataobjects` if `datatype == somedatatype1` then `name = sonemewname1`.",
      "The simplest and perhaps most efficient solution to the problem as stated is:",
      ".input_dataobjects |=\r\n      map( if .datatype == \"somedatatype1\"\r\n           then .name = \"sonemewname1\"\r\n           else . end )"
    ],
    "utterance": "Change the value of 'name' to 'sonemewname1' for objects within 'input_dataobjects' where 'datatype' equals 'somedatatype1'.",
    "expressions": [
      ".input_dataobjects |= map(if .datatype == \"somedatatype1\" then .name = \"sonemewname1\" else . end)"
    ],
    "data": [
      {
        "input": {
          "name": "name",
          "id": [
            "abcdef"
          ],
          "input_dataobjects": [
            {
              "id": "someid1",
              "name": "somename1",
              "provider": "someprovider",
              "datatype": "somedatatype1"
            },
            {
              "name": "some_name2",
              "datatype": "some_datatype2",
              "id": "some_id2"
            }
          ]
        },
        "output": {
          "name": "name",
          "id": [
            "abcdef"
          ],
          "input_dataobjects": [
            {
              "id": "someid1",
              "name": "sonemewname1",
              "provider": "someprovider",
              "datatype": "somedatatype1"
            },
            {
              "name": "some_name2",
              "datatype": "some_datatype2",
              "id": "some_id2"
            }
          ]
        }
      }
    ],
    "identifier": 55257392
  },
  {
    "context": [
      "So, from the above list, how can identify the duplicates and list them.",
      "Since the given input consists of a stream of string-valued arrays, we can write:",
      "bagof(inputs | .[0])\n    | with_entries(select(.value > 1))\n    | keys_unsorted"
    ],
    "utterance": "Find all IP addresses that appear more than once in an input stream where each line is a single-element array containing an IP address.",
    "expressions": [
      "def bagof(stream): reduce stream as $x ({}; .[$x] += 1); bagof(inputs | .[0]) | with_entries(select(.value > 1)) | keys_unsorted"
    ],
    "data": [
      {
        "input": [
          [
            "4.2.1.9"
          ],
          [
            "4.2.1.1"
          ],
          [
            "4.2.1.9"
          ],
          [
            "4.2.1.102"
          ],
          [
            "4.2.4.131"
          ],
          [
            "4.2.1.2"
          ],
          [
            "1.23.39.33"
          ],
          [
            "1.218.4.4"
          ],
          [
            "4.2.1.2"
          ],
          [
            "1.218.1.1"
          ],
          [
            "4.2.4.19"
          ],
          [
            "4.2.1.26"
          ],
          [
            "4.2.4.58"
          ],
          [
            "4.2.4.13"
          ],
          [
            "4.2.4.29"
          ],
          [
            "1.23.39.49"
          ],
          [
            "1.23.39.241"
          ],
          [
            "4.2.1.93"
          ],
          [
            "4.2.4.54"
          ],
          [
            "4.2.4.12"
          ],
          [
            "4.2.4.50"
          ]
        ],
        "output": [
          "4.2.1.9",
          "4.2.1.2"
        ]
      }
    ],
    "identifier": 55255302
  },
  {
    "context": [
      "I would like to return a single value `true` if one of the \n\n    Key=\"aws:cloudformation:stack-name\" \n\nis detected and without given me a list of value back.",
      "jq '.Tags | map( .Key == \"aws:cloudformation:stack-name\" ) |  any ' ",
      "any(.Tags[]; .Key == \"aws:cloudformation:stack-name\")",
      "If you want `true` or nothing at all, you could tack on `// empty` to the above."
    ],
    "utterance": "Return true if any element in the Tags array has Key equal to \"aws:cloudformation:stack-name\"; otherwise return false.",
    "expressions": [
      ".Tags | map(.Key == \"aws:cloudformation:stack-name\") | any",
      "any(.Tags[]; .Key == \"aws:cloudformation:stack-name\")"
    ],
    "data": [
      {
        "input": {
          "Tags": [
            {
              "Value": "INF-D-XX-SEC-OPNV-UW1",
              "Key": "Name"
            },
            {
              "Value": "INF-D-XX-CFS-StandardInfrastructure-UW1",
              "Key": "aws:cloudformation:stack-name"
            },
            {
              "Value": "sgOpenVPNAccess",
              "Key": "aws:cloudformation:logical-id"
            },
            {
              "Value": "UW1",
              "Key": "Location"
            },
            {
              "Value": "INF",
              "Key": "Application"
            },
            {
              "Value": "D",
              "Key": "Parent Environment"
            },
            {
              "Value": "arn:aws:cloudformation:us-west-1:111111:stack/INF-D-XX-CFS-StandardInfrastructure-UW1/1111-11-11e8-96fe-11",
              "Key": "aws:cloudformation:stack-id"
            },
            {
              "Value": "OPNV",
              "Key": "ResourceType"
            }
          ]
        },
        "output": true
      }
    ],
    "identifier": 55252911
  },
  {
    "context": [
      "Input :\r\n\r\n    {\r\n      \"0\": {\r\n        \"filed1\": \"xxxx\",\r\n        \"field\": \"zzzz\"\r\n        \r\n      },\r\n      \"1\": {\r\n        \"field1\": \"xxx\",\r\n        \"filed2\": \"zzz\"\r\n      }\r\n    }",
      "Desired output, I don't want to store my field in an id body, instead I want to save my id alongside of the others fields as in a flat objet \r\n\r\n    {\r\n      {\r\n        \"id\": 0,\r\n        \"filed1\": \"xxxx\",\r\n        \"field\": \"zzzz\"\r\n      },\r\n      {\r\n        \"id\": 2,\r\n        \"field1\": \"xxx\",\r\n        \"filed2\": \"zzz\"\r\n      }\r\n    }",
      "This can be done using [`to_entries`][1] and the `*` operator:\r\n\r\n    jq 'to_entries | map({id: .key} * .value)' file.json"
    ],
    "utterance": "Flatten an object with numbered keys into an array of objects, each merging the key as an 'id' field with the corresponding sub-object's fields.",
    "expressions": [
      "to_entries | map({id: .key} * .value)"
    ],
    "data": [
      {
        "input": {
          "0": {
            "filed1": "xxxx",
            "field": "zzzz"
          },
          "1": {
            "field1": "xxx",
            "filed2": "zzz"
          }
        },
        "output": [
          {
            "id": "0",
            "filed1": "xxxx",
            "field": "zzzz"
          },
          {
            "id": "1",
            "field1": "xxx",
            "filed2": "zzz"
          }
        ]
      }
    ],
    "identifier": 55246560
  },
  {
    "context": [
      "Is there more elegant and readable way to remove escaped quotes for the first and second fields--and overall, to build a stream of objects given such input?",
      "Your invocation of jq can be simplified to:\r\n\r\n    jq -R '\r\n      split(\",\")\r\n      | map(fromjson)\r\n      | {ID: .[0], date: .[1], count: .[2] }'",
      "Generic solution\r\n\r\n    jq -R --argjson header '[\"ID\", \"date\", \"count\"]' '\r\n      split(\",\")\r\n      | map(fromjson)\r\n      | [ $header, . ]\r\n      | transpose\r\n      | reduce .[] as $kv ({}; .[$kv[0]] =$kv[1]) '"
    ],
    "utterance": "Remove escaped quotes from the first two fields of each row in a CSV without headers and output objects with fields ID, date, and count.",
    "expressions": [
      "split(\",\") | map(fromjson) | {ID: .[0], date: .[1], count: .[2]}",
      "--argjson header '[\"ID\", \"date\", \"count\"]' split(\",\") | map(fromjson) | [ $header, . ] | transpose | reduce .[] as $kv ({}; .[$kv[0]] = $kv[1])"
    ],
    "data": [
      {
        "input": "\"12345678901234567890\",\"2019-03-19\",12",
        "output": {
          "ID": "12345678901234567890",
          "date": "2019-03-19",
          "count": 12
        }
      }
    ],
    "identifier": 55247622
  },
  {
    "context": [
      "But I have the \"array  is not valid in a csv row\" error",
      "You need to JSON-encode the call-to-action first.",
      ".records[] | [.id, .metadata.description, .metadata.width, .metadata.height, .metadata.secondaryColor, (.metadata.callToAction|@json), .parent] | @tsv",
      "Since the stated goal includes \"null\" in the output, you might like to consider mapping all the selected values using `tojson`, e.g. using `map(tojson)`."
    ],
    "utterance": "Produce a tab-separated row for each record, keeping all fields as-is except for the callToAction array, which should be serialized as a JSON string so the array structure is preserved in the output.",
    "expressions": [
      ".records[] | [.id, .metadata.description, .metadata.width, .metadata.height, .metadata.secondaryColor, (.metadata.callToAction|@json), .parent] | @tsv",
      ".records[] | [.id, .metadata.description, .metadata.width, .metadata.height, .metadata.secondaryColor, .metadata.callToAction, .parent] | map(if type == \"string\" then . else tojson end) | @tsv"
    ],
    "data": [
      {
        "input": {
          "records": [
            {
              "id": 1,
              "metadata": {
                "description": null,
                "width": 0,
                "height": 0,
                "secondaryColor": "#fff",
                "callToAction": [
                  {
                    "link": "/truc.html",
                    "value": "nice",
                    "colors": {
                      "primary": "transparent;",
                      "secondary": "transparent;"
                    }
                  }
                ]
              },
              "parent": null
            }
          ]
        },
        "output": "1\tnull\t0\t0\t#fff\t[{\"link\":\"/truc.html\",\"value\":\"nice\",\"colors\":{\"primary\":\"transparent;\",\"secondary\":\"transparent;\"}}]\tnull"
      }
    ],
    "identifier": 55262718
  },
  {
    "context": [
      "I would like to merge all the arrays to a single array as shown in the output needed below.",
      "Your problem description indicates you simply want to concatenate the arrays, which can easily be done using the \"slurp\" command-line option:",
      "jq -s add",
      "If efficiency is an issue, which it might be if the number of input arrays is very large, then you could take advantage of the stream-oriented nature of the input:",
      "jq -n 'reduce inputs as $in ([]; .+$in)'"
    ],
    "utterance": "Merge multiple input arrays into a single array containing all their elements, preserving order.",
    "expressions": [
      "jq -s add",
      "jq -n 'reduce inputs as $in ([]; .+$in)'"
    ],
    "data": [
      {
        "input": [
          [
            {
              "key": "65",
              "type": "Rug"
            },
            {
              "key": "66",
              "type": "Rug"
            }
          ],
          [
            {
              "key": "52",
              "type": "A"
            }
          ]
        ],
        "output": [
          {
            "key": "65",
            "type": "Rug"
          },
          {
            "key": "66",
            "type": "Rug"
          },
          {
            "key": "52",
            "type": "A"
          }
        ]
      }
    ],
    "identifier": 55270878
  },
  {
    "context": [
      "How can I remove from the array the section with name `prerequisite` using the command line? ",
      "jq '.sections |= map(select(.name != \"Prerequisite\"))' docs.json"
    ],
    "utterance": "Remove the object with name 'Prerequisite' from the sections array in the file when using the command line.",
    "expressions": [
      ".sections |= map(select(.name != \"Prerequisite\"))"
    ],
    "data": [
      {
        "input": {
          "ignore": [
            "**/__tests__/**",
            "**/*.test.{js,jsx,ts,tsx}",
            "**/*.spec.{js,jsx,ts,tsx}",
            "**/*.d.ts"
          ],
          "sections": [
            {
              "name": "Introduction",
              "content": "docs/introduction.md"
            },
            {
              "name": "Prerequisite",
              "content": "docs/prerequisite.md"
            }
          ]
        },
        "output": {
          "ignore": [
            "**/__tests__/**",
            "**/*.test.{js,jsx,ts,tsx}",
            "**/*.spec.{js,jsx,ts,tsx}",
            "**/*.d.ts"
          ],
          "sections": [
            {
              "name": "Introduction",
              "content": "docs/introduction.md"
            }
          ]
        }
      }
    ],
    "identifier": 55273956
  },
  {
    "context": [
      "I would like to extract the services name thanks to [`yq`](https://github.com/kislyuk/yq), an equivalent of `jq` but for YAML, to have this output:",
      "\"apache\"\n\"mysql\"\n\"php\"",
      "cat docker-compose.yml | yq '.services | keys[]'",
      "yq '.services | keys[]' docker-compose.yml"
    ],
    "utterance": "List all the keys of the 'services' object at the top level whose values contain image and restart fields.",
    "expressions": [
      ".services | keys[]"
    ],
    "data": [
      {
        "input": {
          "networks": {
            "foo": {
              "some_opts": "covfefe"
            },
            "bar": {
              "some_opts": "such wow"
            }
          },
          "services": {
            "apache": {
              "image": "apache:1.0.0",
              "restart": "always"
            },
            "mysql": {
              "image": "mysql:1.0.0",
              "restart": "always"
            },
            "php": {
              "image": "php",
              "restart": "always"
            }
          }
        },
        "output": [
          "apache",
          "mysql",
          "php"
        ]
      }
    ],
    "identifier": 55280071
  },
  {
    "identifier": 55306538
  },
  {
    "context": [
      "curl \"https://api.sunrise-sunset.org/json?lat=46.745995&lng=7.122781&date=today\" | jq '.results.sunrise'",
      "the result is :\n\n\"5:31:51 AM\"",
      "I am living in UTC+1 and I need to add one hour in the same command.",
      "jq '.results.sunrise\n    | strptime(\"%I:%M:%S %p\")\n    | {h: ((.[3] + 1) % 24), m:.[4], s:.[5]}\n    | if .h < 12 then \"\\(.h):\\(.m):\\(.s) AM\"\n      elif .h == 12 then \"\\(.h):\\(.m):\\(.s) PM\"\n      else \"\\(.h - 12):\\(.m):\\(.s) PM\"\n      end '"
    ],
    "utterance": "Take the 'sunrise' field and add one hour to its time, outputting the result in the same AM/PM format.",
    "expressions": [
      ".results.sunrise | strptime(\"%I:%M:%S %p\") | {h: ((.[3] + 1) % 24), m:.[4], s:.[5]} | if .h < 12 then \"\\(.h):\\(.m):\\(.s) AM\" elif .h == 12 then \"\\(.h):\\(.m):\\(.s) PM\" else \"\\(.h - 12):\\(.m):\\(.s) PM\" end"
    ],
    "data": [
      {
        "input": {
          "results": {
            "sunrise": "5:31:51 AM"
          }
        },
        "output": "6:31:51 AM"
      }
    ],
    "identifier": 55279736
  },
  {
    "context": [
      "jq --arg key \"$key\" --arg value \"$value\" '.parameters |= map( if .name == $key then .default = $value else . end )' cam.json > cam1.json",
      "create a dictionary ($dict) of key-value pairs, which can easily be done using the builtin filter INDEX/1:",
      "INDEX(inputs | split(\":\") | select(.[1] | length > 0); .[0])",
      "| map_values(.[1]) as $dict",
      "| $cam",
      "| .parameters |= map( $dict[.name] as $value | if $value then .default = $value else . end )",
      "jq -n -R -f program.jq --argfile cam cam.json prop.properties > cam1.json && mv cam1.json cam.json"
    ],
    "utterance": "Replace values of the 'default' field for each parameter object if its name matches a key from a properties file, where the value may contain spaces.",
    "expressions": [
      "jq --arg key \"$key\" --arg value \"$value\" '.parameters |= map( if .name == $key then .default = $value else . end )' cam.json",
      "INDEX(inputs | split(\":\") | select(.[1] | length > 0); .[0])\n| map_values(.[1]) as $dict\n| $cam\n| .parameters |= map( $dict[.name] as $value | if $value then .default = $value else . end )"
    ],
    "data": [
      {
        "input": {
          "name": "${p:Instance_Name}",
          "parameters": [
            {
              "name": "git_con_type",
              "default": "",
              "immutable_after_create": false
            },
            {
              "name": "git_host_fqdn",
              "default": "hello",
              "immutable_after_create": false
            },
            {
              "name": "git_user",
              "default": "",
              "immutable_after_create": false
            },
            {
              "name": "git_user_password",
              "default": "Passw0rd",
              "immutable_after_create": false
            },
            {
              "name": "git_repo",
              "default": "lm",
              "immutable_after_create": false
            },
            {
              "name": "git_repo_user",
              "default": "-Life",
              "immutable_after_create": false
            },
            {
              "name": "git_branch",
              "default": "master",
              "immutable_after_create": false
            },
            {
              "name": "git_clone_dir",
              "default": "/opt/git",
              "immutable_after_create": false
            }
          ]
        },
        "output": {
          "name": "${p:Instance_Name}",
          "parameters": [
            {
              "name": "git_con_type",
              "default": "something",
              "immutable_after_create": false
            },
            {
              "name": "git_host_fqdn",
              "default": "something again",
              "immutable_after_create": false
            },
            {
              "name": "git_user",
              "default": "something again again",
              "immutable_after_create": false
            },
            {
              "name": "git_user_password",
              "default": "something",
              "immutable_after_create": false
            },
            {
              "name": "git_repo",
              "default": "something",
              "immutable_after_create": false
            },
            {
              "name": "git_repo_user",
              "default": "",
              "immutable_after_create": false
            },
            {
              "name": "git_branch",
              "default": "",
              "immutable_after_create": false
            },
            {
              "name": "git_clone_dir",
              "default": "/opt/git",
              "immutable_after_create": false
            }
          ]
        }
      }
    ],
    "identifier": 55268512
  },
  {
    "context": [
      "Next step is I will be running shell with runtime argumnts command (./shell.sh brand3-nl-nl-live)",
      "which should insert the object in json",
      "To add an argument as key of an object you must do it this way:",
      "jq --arg v $1 '.cores[$v] = { master_url: \"http://master.solr.local:8983/solr/$var\", poll_interval: \"00:01:00\"}' test.json.tmp > test.json"
    ],
    "utterance": "Insert an object with a dynamic key (provided as a shell argument) into the 'cores' object, where the value includes 'master_url' set to a URL containing the key and 'poll_interval' set to '00:01:00'.",
    "expressions": [
      ".cores[$v] = { master_url: (\"http://master.solr.local:8983/solr/\" + $v), poll_interval: \"00:01:00\" }"
    ],
    "data": [
      {
        "input": {
          "cores": {
            "brand1-nl-nl-live": {
              "master_url": "http://master.solr.local:8983/solr/brand1-nl-nl-live",
              "poll_interval": "00:01:00"
            },
            "brand2-nl-nl-live": {
              "master_url": "http://master.solr.local:8983/solr/brand2-nl-nl-live",
              "poll_interval": "00:01:00"
            }
          }
        },
        "output": {
          "cores": {
            "brand1-nl-nl-live": {
              "master_url": "http://master.solr.local:8983/solr/brand1-nl-nl-live",
              "poll_interval": "00:01:00"
            },
            "brand2-nl-nl-live": {
              "master_url": "http://master.solr.local:8983/solr/brand2-nl-nl-live",
              "poll_interval": "00:01:00"
            },
            "brand3-nl-nl-live": {
              "master_url": "http://master.solr.local:8983/solr/brand3-nl-nl-live",
              "poll_interval": "00:01:00"
            }
          }
        }
      }
    ],
    "identifier": 55283016
  },
  {
    "context": [
      "I need to get the output in a format more friendly to send to Jira to make tickets. Specifically, I would like to strip the json formatting away, and insert a `\\n` between each keypair.",
      "DESCRIPTION: Need to run script to do stuff\\nPRIORITY: Medium",
      "STACK_NAME: applecakes\\nBACKEND_OR_INTEGRATIONS: integrations\\nPRIORITY: Medium",
      "Just join what the array of strings with `\\\\n` (the sequence of the `\\` character which we need to escape and the `n` character) and use raw-output : ",
      "jq --raw-output 'to_entries | map(\"\\(.key) : \\(.value)\") | join(\"\\\\n\")'",
      "Or more efficiently and more simply:",
      "jq -r 'to_entries[] | \"\\(.key) : \\(.value)\"'",
      "With your sample JSON, the invocation: ",
      "jq -j -r 'to_entries[] | \"\\(.key) : \\(.value)\", \"\\\\n\" '"
    ],
    "utterance": "Produce a text where each key-value pair from the object is represented as 'KEY: VALUE' and pairs are separated by the two-character sequence '\\n', removing all JSON formatting.",
    "expressions": [
      "to_entries | map(\"\\(.key) : \\(.value)\") | join(\"\\\\n\")",
      "-r 'to_entries[] | \"\\(.key) : \\(.value)\"'",
      "-j -r 'to_entries[] | \"\\(.key) : \\(.value)\", \"\\\\n\" '"
    ],
    "data": [
      {
        "input": {
          "DESCRIPTION": "Need to run script to do stuff",
          "PRIORITY": "Medium"
        },
        "output": "DESCRIPTION : Need to run script to do stuff\\nPRIORITY : Medium"
      },
      {
        "input": {
          "STACK_NAME": "applecakes",
          "BACKEND_OR_INTEGRATIONS": "integrations",
          "PRIORITY": "Medium"
        },
        "output": "STACK_NAME : applecakes\\nBACKEND_OR_INTEGRATIONS : integrations\\nPRIORITY : Medium"
      }
    ],
    "identifier": 55300958
  },
  {
    "context": [
      "I have multiple json objects which could be less when i merge the arrays if a object key matches the same value as the next json object.",
      "should result in:\r\n{\r\n    \"name\": \"a\",\r\n    \"list\": [ \"a1\", \"a2\", \"a3\", \"a4\" ]\r\n}\r\n{\r\n    \"name\": \"b\",\r\n    \"list\": [ \"b1\", \"b2\" ]\r\n}",
      "You can use `reduce` like this:\r\n\r\n    $ jq -c -n 'reduce inputs as $p ({}; .[$p.name] |= { name : $p.name, list : (.list + $p.list) }) | .[]' file",
      "Here's a simple and efficient solution that uses a common \"aggregate by\" technique:\r\n\r\n    reduce inputs as $kv ({}; .[$kv.name] += $kv.list)\r\n    | keys_unsorted[] as $k\r\n    | {name: $k, list: .[$k]}"
    ],
    "utterance": "Merge all objects with the same name by concatenating their list arrays into a single object for each name.",
    "expressions": [
      "reduce inputs as $p ({}; .[$p.name] |= { name : $p.name, list : (.list + $p.list) }) | .[]",
      "reduce inputs as $kv ({}; .[$kv.name] += $kv.list) | keys_unsorted[] as $k | {name: $k, list: .[$k]}"
    ],
    "data": [
      {
        "input": [
          {
            "name": "a",
            "list": [
              "a1",
              "a2"
            ]
          },
          {
            "name": "a",
            "list": [
              "a3",
              "a4"
            ]
          },
          {
            "name": "b",
            "list": [
              "b1",
              "b2"
            ]
          }
        ],
        "output": [
          {
            "name": "a",
            "list": [
              "a1",
              "a2",
              "a3",
              "a4"
            ]
          },
          {
            "name": "b",
            "list": [
              "b1",
              "b2"
            ]
          }
        ]
      }
    ],
    "identifier": 55312306
  },
  {
    "context": [
      "I need to merge two JSON objects based on first object keys",
      "object1 = {\n \"params\" : {\n    \"type\": [\"type1\", \"type2\"],\n    \"requeststate\": []\n }        \n}\n",
      "object2 = {\n \"params\" : {\n    \"type\": [\"type2\", \"type3\", \"type4\"],\n    \"requeststate\": [\"Original\", \"Revised\" ],\n    \"responsestate\": [\"Approved\" ]\n }        \n}\n",
      "my output should look like below",
      "mergedobject = {\n \"params\" : {\n    \"type\": [\"type1\", \"type2\", \"type3\", \"type4\"],\n    \"requeststate\": [\"Original\", \"Revised\"]\n }        \n}\n",
      "I need to merge two object based on first object key and my output should look like below"
    ],
    "utterance": "Combine all keys and array elements from the 'params' objects of two inputs, keeping only the keys present in the first object's 'params', and merging array values uniquely.",
    "expressions": [
      "(.params | keys_unsorted) as $keys | {params: (reduce $keys[] as $k ({}; .[$k] = ((.params[$k] + $ARGS.positional[0].params[$k]) | unique)))}"
    ],
    "data": [
      {
        "input": [
          {
            "params": {
              "type": [
                "type1",
                "type2"
              ],
              "requeststate": []
            }
          },
          {
            "params": {
              "type": [
                "type2",
                "type3",
                "type4"
              ],
              "requeststate": [
                "Original",
                "Revised"
              ],
              "responsestate": [
                "Approved"
              ]
            }
          }
        ],
        "output": {
          "params": {
            "type": [
              "type1",
              "type2",
              "type3",
              "type4"
            ],
            "requeststate": [
              "Original",
              "Revised"
            ]
          }
        }
      }
    ],
    "identifier": 55324361
  },
  {
    "context": [
      "I trying to get the `listaObjeto` from the json.",
      "Here is the error I'm getting :",
      "jq '.hits.hits._source.listaObjeto' jq: error: Cannot index array with string",
      "`.hits.hits` is an array, so you will need to add `[]` to map over it:",
      ".hits.hits[]._source.listaObjeto"
    ],
    "utterance": "Extract all listaObjeto arrays from each element of hits.hits array",
    "expressions": [
      ".hits.hits[]._source.listaObjeto"
    ],
    "data": [
      {
        "input": {
          "took": 42,
          "timed_out": false,
          "_shards": {
            "total": 5,
            "successful": 5,
            "skipped": 0,
            "failed": 0
          },
          "hits": {
            "total": 1,
            "max_score": 11.2367325,
            "hits": [
              {
                "_index": "provflogs-2019.03.26",
                "_type": "Portal",
                "_id": "SQGEumkBYgyBeVm_SiGe",
                "_score": 11.2367325,
                "_source": {
                  "siglaSistema": "SRPO",
                  "dataPesquisa": "2019-03-26T12:00:25.896-0300",
                  "ipRequisitante": "104.238.179.249",
                  "listaObjeto": [
                    "UB711395572YP",
                    "OG461051611BR",
                    "RG968790315CN"
                  ],
                  "loginUsuario": "USER1",
                  "metodoRequisitado": "buscaEventos"
                }
              }
            ]
          }
        },
        "output": [
          [
            "UB711395572YP",
            "OG461051611BR",
            "RG968790315CN"
          ]
        ]
      }
    ],
    "identifier": 55361298
  },
  {
    "context": [
      "I want to be able to match a string where `message==\"Validating...\"`, then get the the next n trailing or leading objects from the match.",
      "# leading three\nfind(.message == \"Validating...\") as $i | .[if $i < 3 then 0 else $i - 3 end:$i]",
      "# trailing three\nfind(.message == \"Validating...\") as $i | .[$k:$k + 4]"
    ],
    "utterance": "Find objects where message equals \"Validating...\" and return n items before or after each match within the array.",
    "expressions": [
      "def find(condition): label $out | foreach .[] as $p (-1; . + 1 | if $p | condition then ., break $out else empty end);",
      "find(.message == \"Validating...\") as $i | .[if $i < 3 then 0 else $i - 3 end : $i]",
      "# leading 3",
      "find(.message == \"Validating...\") as $i | .[$i : $i + 4]",
      "# trailing 3 (match + 3 after)"
    ],
    "data": [
      {
        "input": [
          {
            "message": "Validating..."
          },
          {
            "message": "Validated."
          },
          {
            "message": "Saving..."
          },
          {
            "message": "Saved."
          }
        ],
        "output": [
          {
            "message": "Validating..."
          },
          {
            "message": "Validated."
          },
          {
            "message": "Saving..."
          },
          {
            "message": "Saved."
          }
        ]
      }
    ],
    "identifier": 55378978
  },
  {
    "context": [
      "I have a json array like this:\r\n  \r\n    [\"abc\", 0, \"cd\", 1]",
      "I'm struggling to convert this in a csv:\r\n\r\n    \"abc\", 0\r\n    \"cd\", 1",
      "Generate even indices using `range` and use them for slicing the array:\r\n```jq\r\nrange(0;length;2) as $i | .[$i:$i+2] | @csv\r\n```\r\nNote that `-r` option is required for producing proper CSV."
    ],
    "utterance": "Convert an array [\"abc\", 0, \"cd\", 1] into CSV lines where each line contains a pair of consecutive elements.",
    "expressions": [
      "range(0;length;2) as $i | .[$i:$i+2] | @csv"
    ],
    "data": [
      {
        "input": [
          "abc",
          0,
          "cd",
          1
        ],
        "output": "\"abc\",0\n\"cd\",1"
      }
    ],
    "identifier": 55402677
  },
  {
    "context": [
      "I am looking for a better way to at least extract the fields from jq not using grep. I can live with content preparation using SED, but I feel that there must be a better way to get the fields I want not using grep.",
      "Actually you don't even need grep if you have the latest version of jq, try this:",
      "(paths(scalars) | select(IN(.[];\n    \"_index\",\n    \"current_send_data\",\n    \"ship_send_delay\",\n    \"ship_send_priority\",\n    \"current_ship_status\"\n))) as $p | \"\\($p|join(\".\"))=\\(getpath($p))\""
    ],
    "utterance": "Return all fields whose path includes any of: _index, current_send_data, ship_send_delay, ship_send_priority, or current_ship_status, formatted as key paths joined by dots and values separated by '='.",
    "expressions": [
      "(paths(scalars) | select(IN(.[];\n    \"_index\",\n    \"current_send_data\",\n    \"ship_send_delay\",\n    \"ship_send_priority\",\n    \"current_ship_status\"\n))) as $p | \"\\($p|join(\".\"))=\\(getpath($p))\""
    ],
    "data": [
      {
        "input": {
          "_index": "ships",
          "_type": "doc",
          "_id": "c36806c10a96a3968c07c6a222cfc818",
          "_score": 0.057158414,
          "_source": {
            "user_email": "admin@example.com",
            "current_send_date": 1552557382,
            "next_send_date": 1570798063,
            "data_name": "atari",
            "statistics": {
              "game_mode": "engineer",
              "opened_game": 0,
              "user_score": 0,
              "space_1": {
                "ship_send_priority": 10,
                "ssl_required": "true",
                "ship_send_delay": 15,
                "user_score": 0,
                "template1": {
                  "current_ship_status": "sent",
                  "current_ship_date": "4324242",
                  "checked_link_before_clicked": 0
                },
                "template2": {
                  "current_ship_status": "sent",
                  "current_ship_date": "4324242",
                  "checked_payload": 0
                }
              }
            }
          }
        },
        "output": [
          "_index=ships",
          "_source.current_send_date=1552557382",
          "_source.statistics.space_1.ship_send_priority=10",
          "_source.statistics.space_1.ship_send_delay=15",
          "_source.statistics.space_1.template1.current_ship_status=sent",
          "_source.statistics.space_1.template2.current_ship_status=sent"
        ]
      }
    ],
    "identifier": 55277768
  },
  {
    "context": [
      "So, for each item in the initial `items` array, I want to create an entry in the output's `payload`, i.e I want to map `items[i]` to `payload[i].data.items` while also creating the `payload`, `key` and `data` keys in the output, and setting `payload[i].data.id` and `payload[i].data.name` to the input's outer `id` and `name`.",
      "Sure, you can use the following filter :",
      ".id as $id | .name as $name | {payload : [ .items[] | {key:.id, data:{id:$id, name: $name, items:[.]}} ] }"
    ],
    "utterance": "For each item in the input's items array, create a payload array entry with key set to the item's id and data containing the outer id, name, and an items array with just that item.",
    "expressions": [
      ".id as $id | .name as $name | {payload : [ .items[] | {key:.id, data:{id:$id, name: $name, items:[.]}} ] }"
    ],
    "data": [
      {
        "input": {
          "id": "OUTER_ID",
          "name": "OUTER_NAME",
          "items": [
            {
              "id": "INNER_ID_1",
              "name": "INNER_NAME_1"
            },
            {
              "id": "INNER_ID_2",
              "name": "INNER_NAME_2"
            }
          ]
        },
        "output": {
          "payload": [
            {
              "key": "INNER_ID_1",
              "data": {
                "id": "OUTER_ID",
                "name": "OUTER_NAME",
                "items": [
                  {
                    "id": "INNER_ID_1",
                    "name": "INNER_NAME_1"
                  }
                ]
              }
            },
            {
              "key": "INNER_ID_2",
              "data": {
                "id": "OUTER_ID",
                "name": "OUTER_NAME",
                "items": [
                  {
                    "id": "INNER_ID_2",
                    "name": "INNER_NAME_2"
                  }
                ]
              }
            }
          ]
        }
      }
    ],
    "identifier": 55395872
  },
  {
    "context": [
      "Both have more than 4000 JSON files. The JSON content of every file is like\n\n    {\n       \"someattribute\":\"someValue\",\n       \"url\":[\n          \"https://www.someUrl.com/xyz\"\n       ],\n       \"someattribute\":\"someValue\"\n    }\n\nNote that url is an array, but it always contains one element (the url).\n\nThe url makes the file unique. If there is a file with the same url in `/dir` and `/dir2` then it's a duplicate and it needs to be deleted.",
      "jq -nrj '[\n  foreach inputs.url as [$url] ({};\n    .[$url] += 1;\n    if .[$url] > 1 then input_filename\n    else empty end\n  )\n] | join(\"\\u0000\")' /{dir1,dir2}/*.json"
    ],
    "utterance": "List the filenames of all files in dir1 and dir2 whose url attribute is not unique among all files (i.e., find files with duplicate url values).",
    "expressions": [
      "jq -nrj '[\n  foreach inputs.url as [$url] ({};\n    .[$url] += 1;\n    if .[$url] > 1 then input_filename\n    else empty end\n  )\n] | join(\"\\u0000\")' /{dir1,dir2}/*.json"
    ],
    "data": [
      {
        "input": [
          {
            "file": "dir1/a.json",
            "content": {
              "url": [
                "https://www.someUrl.com/abc"
              ]
            }
          },
          {
            "file": "dir1/b.json",
            "content": {
              "url": [
                "https://www.someUrl.com/xyz"
              ]
            }
          },
          {
            "file": "dir2/c.json",
            "content": {
              "url": [
                "https://www.someUrl.com/xyz"
              ]
            }
          }
        ],
        "output": [
          "dir1/b.json",
          "dir2/c.json"
        ]
      }
    ],
    "identifier": 55346229
  },
  {
    "context": [
      "I need to convert the `Service.Port` field from a string to an integer as that&#39;s what the Consul API requires.",
      "And indeed, if `$msssql_svc_ip` is `10.43.192.146` and `$mssql_svc_port` is `1433`, that gets me: ... `\"Port\": 1433`",
      "jq -n -r --arg MSSQL_IP \"$mssql_svc_ip\" --arg MSSQL_PORT \"$mssql_svc_port\" '{...",
      "\"Port\": ($MSSQL_PORT|tonumber)",
      "Looks like you need to pass the number in with `--argjson` instead of `--arg`:",
      "$ jq -n -r --argjson foo 12 '{\"foo\":$foo}' ... { \"foo\": 12 }"
    ],
    "utterance": "Create an object where the Service.Port field is set to the integer value 1433, not the string",
    "expressions": [
      "jq -n -r --arg MSSQL_IP \"$mssql_svc_ip\" --arg MSSQL_PORT \"$mssql_svc_port\" '{\n  \"Datacenter\": \"dev\",\n  \"Node\": \"database\",\n  \"Address\": $MSSQL_IP,\n  \"Service\": {\n    \"Service\": \"mssql-dev\",\n    \"Port\": ($MSSQL_PORT|tonumber)\n  }\n}'",
      "jq -n -r --arg MSSQL_IP \"$mssql_svc_ip\" --argjson MSSQL_PORT \"$mssql_svc_port\" '{\n  \"Datacenter\": \"dev\",\n  \"Node\": \"database\",\n  \"Address\": $MSSQL_IP,\n  \"Service\": {\n    \"Service\": \"mssql-dev\",\n    \"Port\": $MSSQL_PORT\n  }\n}'"
    ],
    "data": [
      {
        "input": {
          "MSSQL_IP": "10.43.192.146",
          "MSSQL_PORT": "1433"
        },
        "output": {
          "Datacenter": "dev",
          "Node": "database",
          "Address": "10.43.192.146",
          "Service": {
            "Service": "mssql-dev",
            "Port": 1433
          }
        }
      }
    ],
    "identifier": 55404255
  },
  {
    "context": [
      "I am trying to select credential objects only if key `credhub-ref` exist within them from the following JSON:",
      "When I use `cat my_bindings_test2.json |  jq '.resources[] | .entity.credentials'` I get:",
      "Using JQ, how would I get the following result?\n{\n  \"credhub-ref\": \"ref3\"\n}\n{\n  \"credhub-ref\": \"ref4\"\n}",
      "Like this:\n\n    jq '.resources[].entity.credentials|select(has(\"credhub-ref\"))' file.json",
      "If it is guaranteed that `credhub-ref` won't be `null` or `false`, you can use `select(.[\"credhub-ref\"])`:\n\n    jq '.resources[].entity.credentials | select(.[\"credhub-ref\"])' file"
    ],
    "utterance": "Select credential objects where the key 'credhub-ref' exists.",
    "expressions": [
      ".resources[].entity.credentials | select(has(\"credhub-ref\"))",
      ".resources[].entity.credentials | select(.[\"credhub-ref\"])"
    ],
    "data": [
      {
        "input": {
          "total_results": 23,
          "total_pages": 1,
          "prev_url": null,
          "next_url": null,
          "resources": [
            {
              "entity": {
                "credentials": {},
                "binding_options": {},
                "gateway_data": null,
                "gateway_name": "",
                "syslog_drain_url": null,
                "volume_mounts": [],
                "name": null,
                "last_operation": {
                  "type": "create",
                  "state": "succeeded",
                  "description": "",
                  "updated_at": "2018-10-15T19:13:57Z",
                  "created_at": "2018-10-15T19:13:57Z"
                },
                "app_url": "/v2/3"
              }
            },
            {
              "entity": {
                "app_guid": "sd",
                "service_instance_guid": "sd",
                "credentials": {
                  "hostname": "w",
                  "port": 3306
                },
                "binding_options": {},
                "gateway_data": null,
                "gateway_name": "",
                "syslog_drain_url": null,
                "volume_mounts": [],
                "name": null,
                "last_operation": {
                  "type": "create",
                  "state": "succeeded",
                  "description": "",
                  "updated_at": "2018-10-15T19:24:06Z",
                  "created_at": "2018-10-15T19:24:06Z"
                },
                "app_url": "/v2/3"
              }
            },
            {
              "entity": {
                "credentials": {
                  "credhub-ref": "ref3"
                },
                "binding_options": {},
                "gateway_data": null,
                "gateway_name": "",
                "syslog_drain_url": null,
                "volume_mounts": [],
                "name": null,
                "last_operation": {
                  "type": "create",
                  "state": "succeeded",
                  "description": "",
                  "updated_at": "2019-03-19T20:07:27Z",
                  "created_at": "2019-03-19T20:07:27Z"
                },
                "app_url": "/v2/45"
              }
            },
            {
              "entity": {
                "credentials": {
                  "credhub-ref": "ref4"
                },
                "binding_options": {},
                "gateway_data": null,
                "gateway_name": "",
                "syslog_drain_url": null,
                "volume_mounts": [],
                "name": null,
                "last_operation": {
                  "type": "create",
                  "state": "succeeded",
                  "description": "",
                  "updated_at": "2019-03-19T20:07:27Z",
                  "created_at": "2019-03-19T20:07:27Z"
                },
                "app_url": "/v2/45"
              }
            }
          ]
        },
        "output": [
          {
            "credhub-ref": "ref3"
          },
          {
            "credhub-ref": "ref4"
          }
        ]
      }
    ],
    "identifier": 55251603
  },
  {
    "context": [
      "Is there a way to pipe jq to itself so I can use the value of \"level\" as the key to another query?",
      "For this example, I would like to combine these two commands into one:",
      "$ curl -s http://taxonomy.jgi-psf.org/tax/tax_id/48479 | jq '.[] | .level'",
      "\"no rank\"",
      "$ curl -s http://taxonomy.jgi-psf.org/tax/tax_id/48479 | jq '.[] | .\"no rank\".name'",
      "\"environmental samples\"",
      "You may use `level` property value as a key:",
      "$ curl -s http://taxonomy.jgi-psf.org/tax/tax_id/48479 | jq '.[] | .[\"\\(.level)\"].name'",
      "\"environmental samples\""
    ],
    "utterance": "Extract the value of the 'level' property and use it as a dynamic key to retrieve the 'name' field in the same object where the key matches the value of 'level'.",
    "expressions": [
      ".[] | .[\"\\(.level)\"].name"
    ],
    "identifier": 55444476
  },
  {
    "context": [
      "The **safe** way to do this is to pass your variables out-of-band from your code. That is:",
      "companyToken=$(jq -r --arg chkCustomer \"$chkCustomer\" \\\n               '.payload.customerData[$chkCustomer].token' \"$chkFile\")",
      "This prevents a value of chkCustomer that contains jq code from being able to generate output that doesn't actually conform to the input file's contents...",
      "What I need (or expect) is that I can use a variable and execute a jq query to get a result."
    ],
    "utterance": "Extract the token value for the customer whose id matches a shell variable chkCustomer",
    "expressions": [
      ".payload.customerData[\"101\"].token",
      ".payload.customerData[$chkCustomer].token"
    ],
    "data": [
      {
        "input": {
          "status": true,
          "payload": {
            "customerData": {
              "101": {
                "title": "A Company",
                "id": "101",
                "storageGroups": "SHIPPING",
                "priority": "4",
                "originalname": "A Previous Company",
                "allowShipping": true,
                "parentCompany": "0",
                "rating": 0,
                "external": false,
                "application": "primary",
                "applicationName": "form27",
                "live": true,
                "logo": "http://url",
                "beta": false,
                "length": null,
                "token": "QSBQcmV2aW91cyBDb21wYW55LzEwMQ==",
                "active": "1"
              }
            }
          }
        },
        "output": "QSBQcmV2aW91cyBDb21wYW55LzEwMQ=="
      }
    ],
    "identifier": 55433149
  },
  {
    "context": [
      "I have to manually copy-paste the output in place of the original \"choices\" dict.",
      "Is there a way to do the function but still print the surrounding datas ?",
      ".[].choices[] |= (.label | capture(\"^(?<label>.*?) (?<value>[^ ]+)$\"))",
      "def do_extract:\n  if .value == \"\" then\n    (.label | capture(\"^(?<label>.*?) (?<value>[^ ]+)$\"))\n  else\n    .\n  end;",
      ".[].choices[] |= do_extract"
    ],
    "utterance": "For each item, split the label in each choice into the name and country code, setting label to the name and value to the code, while preserving all other data.",
    "expressions": [
      ".[].choices[] |= (.label | capture(\"^(?<label>.*?) (?<value>[^ ]+)$\"))",
      "def do_extract: if .value == \"\" then (.label | capture(\"^(?<label>.*?) (?<value>[^ ]+)$\")) else . end; .[].choices[] |= do_extract"
    ],
    "data": [
      {
        "input": {
          "1": {
            "id": "1",
            "type": "select",
            "label": "country :",
            "choices": {
              "1": {
                "label": "Canada CAN",
                "value": ""
              },
              "2": {
                "label": "United States USA",
                "value": ""
              }
            }
          }
        },
        "output": {
          "1": {
            "id": "1",
            "type": "select",
            "label": "country :",
            "choices": {
              "1": {
                "label": "Canada",
                "value": "CAN"
              },
              "2": {
                "label": "United States",
                "value": "USA"
              }
            }
          }
        }
      }
    ],
    "identifier": 55425773
  },
  {
    "context": [
      "from which I want to extract the 'value' property (i.e. 99) for \"Remaining Capacity % \".",
      "jq --arg instance \"Remaining Capacity % \" \\\n         '.data[].batList[].dataDict[] | select(.name == $instance ).value' json",
      "jq -r '.[].batList[].dataDict[] | select(.name|contains(\"Remaining\")).value' file"
    ],
    "utterance": "Extract the value for the entry with name equal to \"Remaining Capacity % \" in the nested dataDict array.",
    "expressions": [
      ".data[].batList[].dataDict[] | select(.name == \"Remaining Capacity % \").value",
      ".data[].batList[].dataDict[] | select(.name|contains(\"Remaining\")).value"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": 111585,
              "name": "Inverter",
              "batList": [
                {
                  "name": "Battery1",
                  "dataDict": [
                    {
                      "key": "b1_1",
                      "name": "Battery V.",
                      "value": 57.63,
                      "unit": "V"
                    },
                    {
                      "key": "b1_2",
                      "name": "Battery I.",
                      "value": -0.1,
                      "unit": "A"
                    },
                    {
                      "key": "b1_3",
                      "name": "Battery P.",
                      "value": -6,
                      "unit": "W"
                    },
                    {
                      "key": "b1_4",
                      "name": "Inner T.",
                      "value": 25,
                      "unit": "\u2103"
                    },
                    {
                      "key": "b1_5",
                      "name": "Remaining Capacity % ",
                      "value": 99,
                      "unit": "%"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": 99
      }
    ],
    "identifier": 55447931
  },
  {
    "context": [
      "So I want to print the \"CPU\" value if the value within the Tags is NO",
      "The return value on this example would be: \"Identifier-0002\"",
      "You can do something like below. This basically checks inside `LIST`, to see if any of the objects' value is `NO` and get its `CPU` value.",
      "jq '.LIST[] | select(.Tags[].Value == \"NO\")? | .CPU'"
    ],
    "utterance": "Return the CPU value for LIST entries where any Tag's Value is NO.",
    "expressions": [
      ".LIST[] | select(.Tags[].Value == \"NO\")? | .CPU"
    ],
    "data": [
      {
        "input": {
          "LIST": [
            {
              "CPU": "Identifier-0002",
              "Tags": [
                {
                  "Key": "Family",
                  "Value": "X"
                },
                {
                  "Key": "Available",
                  "Value": "NO"
                }
              ]
            },
            {
              "CPU": "Identifier-0001",
              "Tags": [
                {
                  "Key": "Family",
                  "Value": "X"
                },
                {
                  "Key": "Available",
                  "Value": "YES"
                }
              ]
            }
          ]
        },
        "output": "Identifier-0002"
      }
    ],
    "identifier": 55459393
  },
  {
    "context": [
      "SEARCH='.[] | select(.notes[] | select(.body|contains(\"[SOMETEXT]\")))'",
      "jq \"$SEARCH\" json",
      "ary=('.[]' '|' 'select(.notes[] | select(.body|contains(\"[SOMETEXT]\")))')",
      "jq \"${ary[*]}\" json"
    ],
    "utterance": "Select all objects in the array where any of their notes bodies contain the string \"[SOMETEXT]\".",
    "expressions": [
      ".[] | select(.notes[] | select(.body|contains(\"[SOMETEXT]\")))"
    ],
    "data": [
      {
        "input": [
          {
            "id": 74892374923,
            "notes": [
              {
                "id": 8902348023,
                "body": "Some normal text"
              },
              {
                "id": 8094328420,
                "body": "Some more normal text"
              }
            ]
          },
          {
            "id": 729384872903,
            "notes": [
              {
                "id": 983012,
                "body": "Some more more normal text [SOMETEXT]"
              },
              {
                "id": 89023432,
                "body": "Some more more more normal text"
              }
            ]
          }
        ],
        "output": [
          {
            "id": 729384872903,
            "notes": [
              {
                "id": 983012,
                "body": "Some more more normal text [SOMETEXT]"
              },
              {
                "id": 89023432,
                "body": "Some more more more normal text"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 55470725
  },
  {
    "context": [
      "I have a large file with a sequence of JSON objects.  Each object has a value that I want to extract and run through an external program.  How do you instruct `jq` to do this?",
      "For example, if I have the following JSON file: ... and I want to output the RSA public key moduli, I need to execute openssl for each \"pubKey\" value.",
      "This only works for the first \"pubKey\":",
      "$ jq -r '.pubKey' seq.json | openssl rsa -pubin -noout -modulus",
      "Rather than doing this within jq, as jq cannot use program as filter yet, you can do it outside it:",
      "jq -j --slurp 'map(.pubKey) | join(\">\")' seq.json | xargs --delimiter=> -n1 --no-run-if-empty -i sh -c 'echo \"{}\" | openssl rsa -pubin -noout -modulus'",
      "while IFS= read -r -d '' chunk; do openssl rsa -pubin -noout -modulus <<<\"$chunk\"; done < <(jq -j '(.pubKey, \"\\u0000\")' seq.json)"
    ],
    "utterance": "Extract each pubKey field and output their values individually to standard output for processing by an external command.",
    "expressions": [
      ".pubKey",
      "--slurp | map(.pubKey) | join(\">\")",
      "(.pubKey, \"\\u0000\")"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "corp": "Slate Rocks",
            "pubKey": "-----BEGIN PUBLIC KEY-----\nMFowDQYJKoZIhvcNAQEBBQADSQAwRgJBAMBUAZGIzQsPO1PXgjdCJUxcZNc6Y4FY\ncVC+JxZIUfaz0WkLI7H4tiKCsd+2F+3Xf+hObSbdoUi1UuT5uzpsda8CAQM=\n-----END PUBLIC KEY-----",
            "update": "2018-12-10"
          },
          {
            "id": 2,
            "corp": "Pi-ryte",
            "pubKey": "-----BEGIN PUBLIC KEY-----\nMFowDQYJKoZIhvcNAQEBBQADSQAwRgJBALzXcOJvZz2UFPDJphTm++Ho9t+lkTQf\nxH0nSp7lbfCHL5Y5YbnD7pgbD/e/PGIHt+cch3foOlUyH+b0Ht53ZO0CAQM=\n-----END PUBLIC KEY-----",
            "update": "2019-03-14"
          },
          {
            "id": 3,
            "corp": "Marble Dreams",
            "pubKey": "-----BEGIN PUBLIC KEY-----\nMFowDQYJKoZIhvcNAQEBBQADSQAwRgJBAN1L9v8ZbpJ1/GMlNOfGFjQhhO2KTKpj\nOfp97CDUdCAQ6wzLjagGKbySC16/MpnAvoPUmYEtTRtbdH/rdMGdvd8CAQM=\n-----END PUBLIC KEY-----",
            "update": "2018-12-17"
          }
        ],
        "output": [
          "-----BEGIN PUBLIC KEY-----\nMFowDQYJKoZIhvcNAQEBBQADSQAwRgJBAMBUAZGIzQsPO1PXgjdCJUxcZNc6Y4FY\ncVC+JxZIUfaz0WkLI7H4tiKCsd+2F+3Xf+hObSbdoUi1UuT5uzpsda8CAQM=\n-----END PUBLIC KEY-----",
          "-----BEGIN PUBLIC KEY-----\nMFowDQYJKoZIhvcNAQEBBQADSQAwRgJBALzXcOJvZz2UFPDJphTm++Ho9t+lkTQf\nxH0nSp7lbfCHL5Y5YbnD7pgbD/e/PGIHt+cch3foOlUyH+b0Ht53ZO0CAQM=\n-----END PUBLIC KEY-----",
          "-----BEGIN PUBLIC KEY-----\nMFowDQYJKoZIhvcNAQEBBQADSQAwRgJBAN1L9v8ZbpJ1/GMlNOfGFjQhhO2KTKpj\nOfp97CDUdCAQ6wzLjagGKbySC16/MpnAvoPUmYEtTRtbdH/rdMGdvd8CAQM=\n-----END PUBLIC KEY-----"
        ]
      }
    ],
    "identifier": 55445669
  },
  {
    "context": [
      "I need to modify an element --an array-- (e.g.: \"group-xyz\") within a nested object in a JSON tree using JQ but once that's done then I need the entire object back with the modified data.",
      "The goal is to update a JSON tree and save it in full.",
      "e.g.: add array element, empty array, etc.",
      "{\n  \"group-abc\": {\"users\": [\"tina.turner\"]},\n  \"group-def\": {\"users\": [\"someone.else\"]},\n  \"group-xyz\": {\"users\": [\"that.thing\"]\n}",
      "Then I am interested in returning an object like this:",
      "{\n  \"group-abc\": {\"users\": [\"tina.turner\"]},\n  \"group-def\": {\"users\": []},\n  \"group-xyz\": {\"users\": [\"that.thing\",\"well.done\"]\n}",
      "jq '. |= map( if ( .group==\"abc\") then .users+=[\"final.answer\",] else . end)' source.json",
      "[\n    {\n        \"group\": \"abc\",\n        \"users\": [\n            \"user1\",\n            \"user2\",\n            \"final.answer\"\n        ]\n    },\n    {\n        \"group\": \"def\",\n        \"users\": [\n            \"user4\",\n            \"user5\"\n        ]\n    }\n]"
    ],
    "utterance": "Add the value \"well.done\" to the \"users\" array of key \"group-xyz\", set the \"users\" array of key \"group-def\" to be empty, and return the entire object with these modifications.",
    "expressions": [
      ".\"group-xyz\".users += [\"well.done\"] | .\"group-def\".users = []"
    ],
    "data": [
      {
        "input": {
          "group-abc": {
            "users": [
              "tina.turner"
            ]
          },
          "group-def": {
            "users": [
              "someone.else"
            ]
          },
          "group-xyz": {
            "users": [
              "that.thing"
            ]
          }
        },
        "output": {
          "group-abc": {
            "users": [
              "tina.turner"
            ]
          },
          "group-def": {
            "users": []
          },
          "group-xyz": {
            "users": [
              "that.thing",
              "well.done"
            ]
          }
        }
      }
    ],
    "identifier": 55466748
  },
  {
    "context": [
      "The problem are the JSON objects with a numeric identifier. On jqplay I got the correct values. On PowerShell `jq` I get an error.",
      "Numbers in the json path need to be marked Oldschool like:\r\n.starbase_detailed_scan.resources[\"2614028847\"]"
    ],
    "utterance": "Extract values from object fields whose keys are numbers using bracket notation with string keys.",
    "expressions": [
      ".resources[\"325683920\"].current_amount",
      ".resources[\"743985951\"].current_amount",
      ".resources[\"2614028847\"].current_amount"
    ],
    "identifier": 55511484
  },
  {
    "context": [
      "I would like to transform this dictionary into a simple `{key:value, key:value}` format, where if I have nested objects or lists the keys merge in the flattened key string.",
      "The problem is also that some items returned by the API might not necessarily have all the key:value pairs, as some of these are optional. **If the key:value pair is absent then I'd like to insert an `NA`.**",
      "assuming `items` array always has one element, make use of `--stream` option;",
      "reduce (inputs|select(length == 2)) as $p\n({}; .[$p[0]|map(strings)|join(\"_\")] = $p[1])",
      "since `inputs` is used, `-n` option is also required."
    ],
    "utterance": "Flatten a nested structure so that each field, regardless of depth, has a single key composed of joined path segments; if any fields are missing, use NA as the value.",
    "expressions": [
      "jq --stream 'reduce (inputs|select(length == 2)) as $p ({}; .[$p[0]|map(strings)|join(\"_\")] = $p[1])'"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "address": {
                "address_line_1": "string",
                "address_line_2": "string",
                "care_of": "string",
                "country": "string",
                "locality": "string",
                "po_box": "string",
                "postal_code": "string",
                "premises": "string",
                "region": "string"
              },
              "address_snippet": "string",
              "appointment_count": "integer",
              "date_of_birth": {
                "month": "integer",
                "year": "integer"
              },
              "description": "string",
              "description_identifiers": [
                "integer"
              ],
              "kind": "string",
              "links": {
                "self": "string"
              },
              "matches": [
                {
                  "address_snippet": [
                    "integer"
                  ],
                  "snippet": [
                    "integer"
                  ],
                  "title": [
                    "integer"
                  ]
                }
              ],
              "snippet": "string",
              "title": "string"
            }
          ],
          "items_per_page": "integer",
          "kind": "string",
          "start_index": "integer",
          "total_results": "integer"
        },
        "output": {
          "items_0_address_address_line_1": "string",
          "items_0_address_address_line_2": "string",
          "items_0_address_care_of": "string",
          "items_0_address_country": "string",
          "items_0_address_locality": "string",
          "items_0_address_po_box": "string",
          "items_0_address_postal_code": "string",
          "items_0_address_premises": "string",
          "items_0_address_region": "string",
          "items_0_address_snippet": "string",
          "items_0_appointment_count": "integer",
          "items_0_date_of_birth_month": "integer",
          "items_0_date_of_birth_year": "integer",
          "items_0_description": "string",
          "items_0_description_identifiers_0": "integer",
          "items_0_kind": "string",
          "items_0_links_self": "string",
          "items_0_matches_0_address_snippet_0": "integer",
          "items_0_matches_0_snippet_0": "integer",
          "items_0_matches_0_title_0": "integer",
          "items_0_snippet": "string",
          "items_0_title": "string",
          "items_per_page": "integer",
          "kind": "string",
          "start_index": "integer",
          "total_results": "integer"
        }
      }
    ],
    "identifier": 55496843
  },
  {
    "context": [
      "My problem occurs when my input scales to hundreds of thousands of lines (GBs of data), in which case slurp becomes too memory-consuming, and `jq` exits with an error.",
      "Is there a way to use `--stream` (and not `--slurp`) to get the wanted output for a very large input file with `jq`?",
      "`--stream` would overcomplicate this task, use `--null-input/-n` option in conjunction with `reduce` instead.",
      "{a: \"xxx\", b: 123}\n| .domains = (reduce (inputs|select(.query_type == \"A\").resp_name) as $d\n  ({}; . + {($d): null}) | keys_unsorted | map(.[:-1]))"
    ],
    "utterance": "Produce an object with fields a: \"xxx\", b: 123, and domains as a unique list of resp_name values (with the trailing dot removed) from all records where query_type equals \"A\" without slurping all data into memory.",
    "expressions": [
      "{a: \"xxx\", b: 123}\n| .domains = (reduce (inputs|select(.query_type == \"A\").resp_name) as $d\n  ({}; . + {($d): null}) | keys_unsorted | map(.[:-1]))"
    ],
    "data": [
      {
        "input": [
          {
            "query_name": "1eaff.example.com.",
            "query_type": "A",
            "resp_name": "ns02.example.com.",
            "resp_type": "A",
            "data": "<ip>"
          },
          {
            "query_name": "1cf0e.example.com.",
            "query_type": "A",
            "resp_name": "ns01.example.com.",
            "resp_type": "A",
            "data": "<ip>"
          },
          {
            "query_name": "1cf0e.example.com.",
            "query_type": "A",
            "resp_name": "ns02.example.com.",
            "resp_type": "A",
            "data": "<ip>"
          },
          {
            "query_name": "1fwsjz2f4ok1ot2hh2illyd1-wpengine.example.com.",
            "query_type": "A",
            "resp_name": "ns01.example.com.",
            "resp_type": "A",
            "data": "<ip>"
          },
          {
            "query_name": "1fwsjz2f4ok1ot2hh2illyd1-wpengine.example.com.",
            "query_type": "A",
            "resp_name": "ns02.example.com.",
            "resp_type": "A",
            "data": "<ip>"
          },
          {
            "query_name": "1a811.example.com.",
            "query_type": "A",
            "resp_name": "ns01.example.com.",
            "resp_type": "A",
            "data": "<ip>"
          }
        ],
        "output": {
          "a": "xxx",
          "b": 123,
          "domains": [
            "ns01.example.com",
            "ns02.example.com"
          ]
        }
      }
    ],
    "identifier": 55499300
  },
  {
    "context": [
      "Desired output is:\nmyapp.us-east-1a.5\nmyapp.us-east-1b.7\nmyapp.us-east-1c.6",
      "This is a way to do it:\n\n    jq -r '.[]|.ASGname as $g|.instance_AZs|group_by(.)[]|\"\\($g).\\(.[0]).\\(length)\"' file.json",
      "reduce instance_AZs to an object where unique array elements are keys to their repetition counts in the array, use it for producing desired output.",
      ".[]\n| .ASGname as $p\n| reduce .instance_AZs[] as $k ({}; .[$k]+=1)\n| keys_unsorted[] as $k\n| \"\\($p).\\($k).\\(.[$k])\""
    ],
    "utterance": "For each object, list each availability zone from instance_AZs with its count, combined with ASGname, in the format ASGname.AZ.count.",
    "expressions": [
      ".[]|.ASGname as $g|.instance_AZs|group_by(.)[]|\"\u0000($g).\u0000(.[0]).\u0000(length)\"",
      ".[]|.ASGname as $p|reduce .instance_AZs[] as $k ({}; .[$k]+=1)|keys_unsorted[] as $k|\"\u0000($p).\u0000($k).\u0000(.[$k])\""
    ],
    "data": [
      {
        "input": [
          {
            "instance_AZs": [
              "us-east-1b",
              "us-east-1b",
              "us-east-1b",
              "us-east-1c",
              "us-east-1c",
              "us-east-1a",
              "us-east-1a",
              "us-east-1c",
              "us-east-1b",
              "us-east-1a",
              "us-east-1a",
              "us-east-1c",
              "us-east-1a",
              "us-east-1b",
              "us-east-1b",
              "us-east-1c",
              "us-east-1c",
              "us-east-1b"
            ],
            "ASGname": "myapp"
          }
        ],
        "output": [
          "myapp.us-east-1a.5",
          "myapp.us-east-1b.7",
          "myapp.us-east-1c.6"
        ]
      }
    ],
    "identifier": 55489052
  },
  {
    "context": [
      "I have the following json array.\r\n\r\n    [\r\n    &quot;bucketName=myBucket&quot;,\r\n    ]",
      "I am getting the following error:\r\n```\r\njq: error (at parameters.json:3): Cannot index array with string &quot;bucketName&quot;\r\n```\r\nHow can extract the value myBucket?",
      "$ jq '.[] | split(\"=\") | select(.[0]==\"bucketName\")[1]' <<< '[\"bucketName=myBucket\", \"a=b\"]'\n\"myBucket\""
    ],
    "utterance": "Extract the value assigned to bucketName from an array of key=value strings, returning myBucket.",
    "expressions": [
      ".[] | split(\"=\") | select(.[0]==\"bucketName\")[1]"
    ],
    "data": [
      {
        "input": [
          "bucketName=myBucket",
          "a=b"
        ],
        "output": "myBucket"
      }
    ],
    "identifier": 55522216
  },
  {
    "context": [
      "I wanted to merge details one of property of file1 and file2 inside another file3 along with rest of the property details.",
      "OutPut Expected: ...\n  \"swirl_app\": {\n    \"git_repo_name\": \"demo_app\",\n    \"git_branch_name\": \"Release_Sprint1912\",\n    \"git_commit_number\": \"1f227bb19343d19629b302c425adb8f21f4fab5a\",\n    \"version\": \"readBuildInfo_311\",\n    ...",
      "$ jq -s 'add | .swirl_app = .demo_app + .swirl_app' j{1,2}.json > j3.json"
    ],
    "utterance": "Combine all top-level properties from two data files, and set the 'swirl_app' property to the merged result of 'demo_app' from the first file and 'swirl_app' from the second file.",
    "expressions": [
      "jq -s 'add | .swirl_app = .demo_app + .swirl_app' j1.json j2.json"
    ],
    "data": [
      {
        "input": {
          "j1.json": {
            "catalog": {
              "git_branch_name": "Release_Sprint1912",
              "git_commit_number": "7ff5358b6d919228ae6043f7bb64abd890c6dfe9",
              "git_repo_name": "catalog"
            },
            "swirl_components": {
              "git_branch_name": "Release_Sprint1912",
              "git_commit_number": "78ed0b1d0e25a261b89160a037530cf6c594892f",
              "git_repo_name": "swirl_components"
            },
            "demo_app": {
              "git_repo_name": "demo_app",
              "git_branch_name": "Release_Sprint1912",
              "git_commit_number": "1f227bb19343d19629b302c425adb8f21f4fab5a"
            }
          },
          "j2.json": {
            "swirl_app": {
              "version": "readBuildInfo_311",
              "image_name": "/swirl_app:readBuildInfo_311",
              "date_time": "Mon Mar 25 05:55:45 UTC 2019",
              "git_latest_commit": "4b7bef6970f83e6e7fc04302c8b29d7cfd4a1885",
              "jenkins_build_url": "http://10.229.6.14/job/HC_Dev/job/Code-Build/job/swirl_app/311/",
              "artifactory_path": "ARTIFACTORY PATH"
            }
          }
        },
        "output": {
          "catalog": {
            "git_branch_name": "Release_Sprint1912",
            "git_commit_number": "7ff5358b6d919228ae6043f7bb64abd890c6dfe9",
            "git_repo_name": "catalog"
          },
          "swirl_components": {
            "git_branch_name": "Release_Sprint1912",
            "git_commit_number": "78ed0b1d0e25a261b89160a037530cf6c594892f",
            "git_repo_name": "swirl_components"
          },
          "demo_app": {
            "git_repo_name": "demo_app",
            "git_branch_name": "Release_Sprint1912",
            "git_commit_number": "1f227bb19343d19629b302c425adb8f21f4fab5a"
          },
          "swirl_app": {
            "git_repo_name": "demo_app",
            "git_branch_name": "Release_Sprint1912",
            "git_commit_number": "1f227bb19343d19629b302c425adb8f21f4fab5a",
            "version": "readBuildInfo_311",
            "image_name": "/swirl_app:readBuildInfo_311",
            "date_time": "Mon Mar 25 05:55:45 UTC 2019",
            "git_latest_commit": "4b7bef6970f83e6e7fc04302c8b29d7cfd4a1885",
            "jenkins_build_url": "http://10.229.6.14/job/HC_Dev/job/Code-Build/job/swirl_app/311/",
            "artifactory_path": "ARTIFACTORY PATH"
          }
        }
      }
    ],
    "identifier": 55423095
  },
  {
    "context": [
      "I always get **invalid_payload** , because the status be escaped.",
      "`--arg key value` treats value as a string. Since a string containing literal `\"`s needs to have escapes added to be valid in JSON, that's what `jq` does.",
      "`--argjson key value`, by contrast, parses `value` as JSON text; which appears to be what you want to do here.",
      "Change `--arg attachments \"$status\"` to `--argjson attachments \"$status\"`."
    ],
    "utterance": "Insert the result of an API request as a JSON object into the attachments field of a Slack message payload without string escaping.",
    "expressions": [
      "jq -n --arg channel \"#unicorn_log\" \\\n    --arg username \"Kuasa Search Report\" \\\n    --arg text \"${msg}\" \\\n    --arg icon_emoji \"chart_with_upwards_trend\" \\\n    --argjson attachments \"$status\" '$json_template'"
    ],
    "data": [
      {
        "input": {
          "foo": 1000,
          "bar": 100
        },
        "output": {
          "channel": "#unicorn_log",
          "username": "Kuasa Search Report",
          "text": "some message",
          "icon_emoji": "chart_with_upwards_trend",
          "attachments": {
            "foo": 1000,
            "bar": 100
          }
        }
      }
    ],
    "identifier": 55574326
  },
  {
    "context": [
      "I use following jq command actually to join them into a new array:\r\n\r\n    .player_container | .[] | [{ user_id: .[]}]\r\nBut it generates different json Arrays and not one. What i need looks like:",
      "You only have to move one character:\r\n\r\n```\r\n[.player_container | .[] | { user_id: .[]}]\r\n```\r\n\r\nWhile your version creates a separate array for each output of `.player_container | .[]`, this will collect everything into one array."
    ],
    "utterance": "Produce a single array containing objects with a user_id key, merging all inner arrays from every key of player_container, so each value appears as { \"user_id\": value }.",
    "expressions": [
      "[.player_container | .[] | { user_id: .[] }]"
    ],
    "data": [
      {
        "input": {
          "player_container": {
            "74016": [
              "None",
              "None",
              "None",
              "None",
              "None",
              "None",
              "None",
              "None"
            ],
            "74002": [
              "None",
              "None",
              "None",
              "ta81a928e0624295b01499d7035d0308",
              "tdd4e222600d42f9954b0be0448da0b1",
              "None",
              "None",
              "None"
            ],
            "74007": [
              "None",
              "None",
              "None",
              "None",
              "None",
              "None",
              "None",
              "None"
            ],
            "74009": [
              "None",
              "None",
              "None",
              "None",
              "None",
              "None",
              "kcb810a423dd4e179027f0feaae9ea60",
              "None"
            ],
            "74012": [
              "x720ed571876471fab173ba05f71e4b3",
              "None",
              "None",
              "None",
              "None",
              "None",
              "None",
              "None"
            ],
            "74013": [
              "None",
              "None",
              "None",
              "None",
              "None",
              "None",
              "None",
              "None"
            ],
            "74014": [
              "vd86094b5a6e448f8c416d6fe75bec7c",
              "None",
              "None",
              "h6ef696cf767464f9c367150fdb29fe4",
              "None",
              "g77b124cd46b41399c3db219ac0a76bd",
              "None",
              "None"
            ],
            "74015": [
              "None",
              "None",
              "None",
              "None",
              "None",
              "None",
              "None",
              "None"
            ]
          }
        }
      }
    ],
    "identifier": 55491067
  },
  {
    "context": [
      "I am trying to select the credentials object and specific parent level objects only if the key credhub-ref exist within the credential object",
      "I need a query that outputs the parent objects `app_guid` and `service_instance_guid` too like the following:",
      "jq '.resources[].entity | select(.credentials.\"credhub-ref\") | {app_guid, service_instance_guid, credentials}' test.json",
      "It will search for .credentials.credhub-ref in every entity object and will return app_guid, service_instance_guid, credentials as object if found."
    ],
    "utterance": "Return the app_guid, service_instance_guid, and credentials for each resource where the credentials include the credhub-ref key.",
    "expressions": [
      ".resources[].entity | select(.credentials.\"credhub-ref\") | {app_guid, service_instance_guid, credentials}"
    ],
    "data": [
      {
        "input": {
          "total_results": 23,
          "total_pages": 1,
          "prev_url": null,
          "next_url": null,
          "resources": [
            {
              "metadata": {
                "guid": "cd",
                "url": "/v2/service_bindings/cd",
                "created_at": "2019-03-04T21:18:53Z",
                "updated_at": "2019-03-04T21:18:53Z"
              },
              "entity": {
                "app_guid": "9c",
                "service_instance_guid": "66",
                "credentials": {
                  "credhub-ref": "/c/54"
                },
                "binding_options": {},
                "gateway_data": null,
                "gateway_name": "",
                "syslog_drain_url": null,
                "volume_mounts": [],
                "name": null,
                "last_operation": {
                  "type": "create",
                  "state": "succeeded",
                  "description": "",
                  "updated_at": "2019-03-04T21:18:53Z",
                  "created_at": "2019-03-04T21:18:53Z"
                },
                "app_url": "/v2/apps/9c",
                "service_instance_url": "/v2/service_instances/66",
                "service_binding_parameters_url": "/v2/service_bindings/cd"
              }
            },
            {
              "metadata": {
                "guid": "cd",
                "url": "/v2/service_bindings/cd",
                "created_at": "2019-03-11T08:49:22Z",
                "updated_at": "2019-03-11T08:49:22Z"
              },
              "entity": {
                "app_guid": "ea",
                "service_instance_guid": "86",
                "credentials": {},
                "binding_options": {},
                "gateway_data": null,
                "gateway_name": "",
                "syslog_drain_url": null,
                "volume_mounts": [],
                "name": null,
                "last_operation": {
                  "type": "create",
                  "state": "succeeded",
                  "description": "",
                  "updated_at": "2019-03-11T08:49:22Z",
                  "created_at": "2019-03-11T08:49:22Z"
                },
                "app_url": "/v2/apps/ea",
                "service_instance_url": "/v2/service_instances/86",
                "service_binding_parameters_url": "/v2/service_bindings/cd"
              }
            },
            {
              "metadata": {
                "guid": "e0",
                "url": "/v2/service_bindings/e0",
                "created_at": "2019-03-19T20:07:25Z",
                "updated_at": "2019-03-19T20:07:25Z"
              },
              "entity": {
                "app_guid": "73",
                "service_instance_guid": "52",
                "credentials": {
                  "hostname": "10.13.7.64",
                  "port": 3306,
                  "name": "cf_52",
                  "username": "w",
                  "password": "w",
                  "uri": "mysql://",
                  "jdbcUrl": "jdbc:mysql://10.193.78.64:"
                },
                "binding_options": {},
                "gateway_data": null,
                "gateway_name": "",
                "syslog_drain_url": null,
                "volume_mounts": [],
                "name": null,
                "last_operation": {
                  "type": "create",
                  "state": "succeeded",
                  "description": "",
                  "updated_at": "2019-03-19T20:07:25Z",
                  "created_at": "2019-03-19T20:07:25Z"
                },
                "app_url": "/v2/apps/73",
                "service_instance_url": "/v2/service_instances/52",
                "service_binding_parameters_url": "/v2/service_bindings/e0"
              }
            },
            {
              "metadata": {
                "guid": "18",
                "url": "/v2/service_bindings/18",
                "created_at": "2019-03-19T20:07:27Z",
                "updated_at": "2019-03-19T20:07:27Z"
              },
              "entity": {
                "app_guid": "73",
                "service_instance_guid": "ae",
                "credentials": {
                  "credhub-ref": "/c/54"
                },
                "binding_options": {},
                "gateway_data": null,
                "gateway_name": "",
                "syslog_drain_url": null,
                "volume_mounts": [],
                "name": null,
                "last_operation": {
                  "type": "create",
                  "state": "succeeded",
                  "description": "",
                  "updated_at": "2019-03-19T20:07:27Z",
                  "created_at": "2019-03-19T20:07:27Z"
                },
                "app_url": "/v2/apps/73",
                "service_instance_url": "/v2/service_instances/aec",
                "service_binding_parameters_url": "/v2/service_bindings/18"
              }
            }
          ]
        },
        "output": [
          {
            "app_guid": "9c",
            "service_instance_guid": "66",
            "credentials": {
              "credhub-ref": "/c/54"
            }
          },
          {
            "app_guid": "73",
            "service_instance_guid": "ae",
            "credentials": {
              "credhub-ref": "/c/54"
            }
          }
        ]
      }
    ],
    "identifier": 55348490
  },
  {
    "context": [
      "When i filter for available volumes i only want the output to be as follows\r\n\r\n    vol-095ac513f0f049ba5",
      "VolumeId is twice nested, you need to identify that with your query\r\n\r\n    valueid=`echo ${value} | jq '.[]|.[]|.VolumeId'`",
      "Or simply:\r\n\r\n    jq '.Volumes[].VolumeId'"
    ],
    "utterance": "Extract the VolumeId of available volumes from the Volumes array.",
    "expressions": [
      ".Volumes[].VolumeId",
      ".[]|.[]|.VolumeId"
    ],
    "data": [
      {
        "input": {
          "Volumes": [
            {
              "AvailabilityZone": "us-east-1d",
              "Attachments": [],
              "Tags": [
                {
                  "Value": "Dev",
                  "Key": "Env"
                },
                {
                  "Value": "Shell",
                  "Key": "Deployment"
                },
                {
                  "Value": "cnx30au - Kafka-Data-Node - /dev/sdg - /abc/data/sda",
                  "Key": "Name"
                }
              ],
              "Encrypted": true,
              "VolumeType": "gp2",
              "VolumeId": "vol-095ac513f0f049ba5",
              "State": "available",
              "KmsKeyId": "arn:aws:kms:us-east-1:709721360603:key/xvfgfr-dsdsd-dsdsds-a00c-dsdsdsd34dsd",
              "SnapshotId": "",
              "Iops": 100,
              "CreateTime": "2019-04-08T21:52:31.473Z",
              "Size": 10
            }
          ]
        },
        "output": "vol-095ac513f0f049ba5"
      }
    ],
    "identifier": 55583325
  },
  {
    "context": [
      "When I tried to filter by keys:\r\n\r\n    # /home/test/show_param_db.sh -p memory -h host00* -f json | jq -r '[\"host001\"]'\r\n\r\n==> null",
      "I'm hoping to get json by hostname. Thanks for all suggestions.",
      "Are you looking only to get the object corresponding to `host001`? You can use `to_entries` and `from_entries` to map between key/value pairs and JSON objects and use a `select()` expression between to match the host needed",
      "jq '.[][] | to_entries | map(select(.key==\"host001\")) | from_entries'",
      "jq --arg host \"host001\" '.[][] | to_entries | map(select(.key==$host)) | from_entries'"
    ],
    "utterance": "Return the object corresponding to host001.",
    "expressions": [
      ".[][] | to_entries | map(select(.key==\"host001\")) | from_entries",
      "--arg host \"host001\" '.[][] | to_entries | map(select(.key==$host)) | from_entries'"
    ],
    "data": [
      {
        "input": [
          {
            "host001": {
              "status": "OK",
              "msg": "",
              "data": [
                {
                  "hi_shared_memory_address": "0"
                },
                {
                  "memory_max_target": "1G"
                },
                {
                  "memory_target": "1G"
                },
                {
                  "shared_memory_address": "0"
                }
              ]
            },
            "host002": {
              "status": "ERROR",
              "msg": "su: user oracle does not exist",
              "data": []
            }
          }
        ],
        "output": {
          "host001": {
            "status": "OK",
            "msg": "",
            "data": [
              {
                "hi_shared_memory_address": "0"
              },
              {
                "memory_max_target": "1G"
              },
              {
                "memory_target": "1G"
              },
              {
                "shared_memory_address": "0"
              }
            ]
          }
        }
      }
    ],
    "identifier": 55583568
  },
  {
    "context": [
      "What I really need is - all the paths which could have the matching key.",
      "paths\n| select(.[-1] | type == \"string\" and contains(\"keyword\"))\n| join(\".\")",
      "jq -r 'paths\n| select(.[-1] | type == \"string\" and contains($q))\n| join(\".\")' file.json --arg q 'keyword'",
      "jq --stream --arg pattern 'IP' '\nselect(length == 2 and any(.[0][] | strings; test($pattern)))\n    | \"\\(.[0] | join(\".\")): \\(.[1])\"\n' input.json",
      "because sometime you do not even know the component you want to filter for before you see what is there."
    ],
    "utterance": "List all object key paths where the key name contains a given substring such as 'IP'.",
    "expressions": [
      "paths | select(.[-1] | type == \"string\" and contains(\"IP\")) | join(\".\")",
      "jq -r 'paths | select(.[-1] | type == \"string\" and contains($q)) | join(\".\")' file.json --arg q 'IP'"
    ],
    "data": [
      {
        "input": {
          "apiVersion": "v1",
          "kind": "Pod",
          "metadata": {
            "creationTimestamp": "2019-03-28T21:09:42Z",
            "labels": {
              "bu": "finance",
              "env": "prod"
            },
            "name": "auth",
            "namespace": "default",
            "resourceVersion": "2786",
            "selfLink": "/api/v1/namespaces/default/pods/auth",
            "uid": "ce73565a-519d-11e9-bcb7-0242ac110009"
          },
          "spec": {
            "containers": [
              {
                "command": [
                  "sleep",
                  "4800"
                ],
                "image": "busybox",
                "imagePullPolicy": "Always",
                "name": "busybox",
                "resources": {},
                "terminationMessagePath": "/dev/termination-log",
                "terminationMessagePolicy": "File",
                "volumeMounts": [
                  {
                    "mountPath": "/var/run/secrets/kubernetes.io/serviceaccount",
                    "name": "default-token-dbpcm",
                    "readOnly": true
                  }
                ]
              }
            ],
            "dnsPolicy": "ClusterFirst",
            "nodeName": "node01",
            "priority": 0,
            "restartPolicy": "Always",
            "schedulerName": "default-scheduler",
            "securityContext": {},
            "serviceAccount": "default",
            "serviceAccountName": "default",
            "terminationGracePeriodSeconds": 30,
            "tolerations": [
              {
                "effect": "NoExecute",
                "key": "node.kubernetes.io/not-ready",
                "operator": "Exists",
                "tolerationSeconds": 300
              },
              {
                "effect": "NoExecute",
                "key": "node.kubernetes.io/unreachable",
                "operator": "Exists",
                "tolerationSeconds": 300
              }
            ],
            "volumes": [
              {
                "name": "default-token-dbpcm",
                "secret": {
                  "defaultMode": 420,
                  "secretName": "default-token-dbpcm"
                }
              }
            ]
          },
          "status": {
            "conditions": [
              {
                "lastProbeTime": null,
                "lastTransitionTime": "2019-03-28T21:09:42Z",
                "status": "True",
                "type": "Initialized"
              },
              {
                "lastProbeTime": null,
                "lastTransitionTime": "2019-03-28T21:09:50Z",
                "status": "True",
                "type": "Ready"
              },
              {
                "lastProbeTime": null,
                "lastTransitionTime": null,
                "status": "True",
                "type": "ContainersReady"
              },
              {
                "lastProbeTime": null,
                "lastTransitionTime": "2019-03-28T21:09:42Z",
                "status": "True",
                "type": "PodScheduled"
              }
            ],
            "containerStatuses": [
              {
                "containerID": "docker://b5be8275555ad70939401d658bb4e504b52215b70618ad43c2d0d02c35e1ae27",
                "image": "busybox:latest",
                "imageID": "docker-pullable://busybox@sha256:061ca9704a714ee3e8b80523ec720c64f6209ad3f97c0ff7cb9ec7d19f15149f",
                "lastState": {},
                "name": "busybox",
                "ready": true,
                "restartCount": 0,
                "state": {
                  "running": {
                    "startedAt": "2019-03-28T21:09:49Z"
                  }
                }
              }
            ],
            "hostIP": "172.17.0.37",
            "phase": "Running",
            "podIP": "10.32.0.4",
            "qosClass": "BestEffort",
            "startTime": "2019-03-28T21:09:42Z"
          }
        },
        "output": [
          "status.hostIP",
          "status.podIP"
        ]
      }
    ],
    "identifier": 55406838
  },
  {
    "context": [
      "I have a onelined json file that looks similar to this",
      "{ \"fieldA\":1, \"fieldB\":\"foo\" }",
      "{ \"fieldA\":2, \"fieldB\":\"bar\" }",
      "{ \"fieldA\":4, \"fieldB\":\"foobar\" }",
      "but I would like to receive this instead:",
      "[{ \"fieldA\":1, \"fieldB\":\"foo\" }, { \"fieldA\":2, \"fieldB\":\"bar\" }, { \"fieldA\":4, \"fieldB\":\"foobar\" }]",
      "You can merge all of the inputs into a single array using `jq -n '[inputs]'`"
    ],
    "utterance": "Combine newline-delimited objects into a single array.",
    "expressions": [
      "jq -n '[inputs]'"
    ],
    "data": [
      {
        "input": [
          {
            "fieldA": 1,
            "fieldB": "foo"
          },
          {
            "fieldA": 2,
            "fieldB": "bar"
          },
          {
            "fieldA": 4,
            "fieldB": "foobar"
          }
        ],
        "output": [
          {
            "fieldA": 1,
            "fieldB": "foo"
          },
          {
            "fieldA": 2,
            "fieldB": "bar"
          },
          {
            "fieldA": 4,
            "fieldB": "foobar"
          }
        ]
      }
    ],
    "identifier": 55599748
  },
  {
    "context": [
      "Would generate this:\r\n\r\n    {\r\n      \"Parameters\" : {\r\n        \"FargateStackSuffix\" : \"production-fargate\",\r\n        \"VPCStackSuffix\": \"production-base-vpc\",\r\n        \"ServiceName\" : \"myservice\",\r\n        \"EnvironmentName\" : \"production\",\r\n        \"ContainerPort\" : \"80\",\r\n        \"ContainerCpu\" : \"256\",\r\n        \"ContainerMemory\" : \"512\",\r\n        \"Path\" : \"*\",\r\n        \"DesiredCount\" : \"3\",\r\n        \"ELBType\" : \"application\",\r\n        \"ELBIpAddressType\": \"ipv4\",\r\n        \"Zone\": \"myservice.example.com\"\r\n      }\r\n    }",
      "Here's one such way you can generate that json. Perhaps the tricky part here is generating the dynamic name for the environment `DesiredCount` and `Zone`. But jq handles that rather easily.",
      "$ jq --arg ServiceName \"myservice\" --arg EnvironmentName \"production\" '.Parameters |=\r\n    {\r\n        FargateStackSuffix,\r\n        VPCStackSuffix,\r\n        $ServiceName,\r\n        $EnvironmentName,\r\n        ContainerPort,\r\n        ContainerCpu,\r\n        ContainerMemory,\r\n        Path,\r\n        DesiredCount: .\"\\($EnvironmentName)DesiredCount\",\r\n        ELBType,\r\n        ELBIpAddressType,\r\n        Zone: .\"\\($EnvironmentName)Zone\"\r\n    }\r\n    ' generator.json > config.json"
    ],
    "utterance": "Generate a parameter object where output fields like DesiredCount and Zone are dynamically selected based on EnvironmentName, and include ServiceName and EnvironmentName as specified values.",
    "expressions": [
      ".Parameters |= {\n    FargateStackSuffix,\n    VPCStackSuffix,\n    ServiceName: $ServiceName,\n    EnvironmentName: $EnvironmentName,\n    ContainerPort,\n    ContainerCpu,\n    ContainerMemory,\n    Path,\n    DesiredCount: .[\"\\($EnvironmentName)DesiredCount\"],\n    ELBType,\n    ELBIpAddressType,\n    Zone: .[\"\\($EnvironmentName)Zone\"]\n}"
    ],
    "data": [
      {
        "input": {
          "Parameters": {
            "FargateStackSuffix": "environment-fargate",
            "VPCStackSuffix": "environment-base-vpc",
            "ContainerPort": "80",
            "ContainerCpu": "256",
            "ContainerMemory": "512",
            "Path": "*",
            "productionDesiredCount": "3",
            "stagingDesiredCount": "2",
            "developmentDesiredCount": "1",
            "ELBType": "application",
            "ELBIpAddressType": "ipv4",
            "productionZone": "service.example.com",
            "stagingZone": "service-staging.example.com",
            "devZone": "service-dev.example.com"
          }
        },
        "output": {
          "Parameters": {
            "FargateStackSuffix": "environment-fargate",
            "VPCStackSuffix": "environment-base-vpc",
            "ServiceName": "myservice",
            "EnvironmentName": "production",
            "ContainerPort": "80",
            "ContainerCpu": "256",
            "ContainerMemory": "512",
            "Path": "*",
            "DesiredCount": "3",
            "ELBType": "application",
            "ELBIpAddressType": "ipv4",
            "Zone": "service.example.com"
          }
        }
      }
    ],
    "identifier": 55579845
  },
  {
    "context": [
      "I was expecting to have both ids (a and b) show up as result of the above command since they both contains `\"randomtext1\"` text under \"input\"|\"obj1\"|\"$link\" and \"input\"|\"obj3\"|\"$link\".",
      "The filter:\n\n    .[]\n    | select(.input[] | .[\"$link\"] | contains(\"randomtext1\")) \n    | .id\n\nproduces:\n\n    \"a\"\n    \"b\""
    ],
    "utterance": "Return the ids of all records where any object under 'input' contains a '$link' value that includes 'randomtext1'.",
    "expressions": [
      ".[] | select(.input[] | .[\"$link\"] | contains(\"randomtext1\")) | .id"
    ],
    "data": [
      {
        "input": [
          {
            "input": {
              "obj1": {
                "$link": "randomtext1"
              },
              "obj2": {
                "$link": "randomtext2"
              }
            },
            "id": "a"
          },
          {
            "input": {
              "obj3": {
                "$link": "randomtext1"
              },
              "obj4": {
                "$link": "randomtext3"
              }
            },
            "id": "b"
          }
        ],
        "output": [
          "a",
          "b"
        ]
      }
    ],
    "identifier": 55661161
  },
  {
    "context": [
      "All objects in array b where attribute x contains a \"z\" in the value of x should be filtered out. The rest should stay in the file.",
      "use `select` with `contains`:",
      "jq '.a.b|=[.[]|select(.x|contains(\"z\")|not)]' file"
    ],
    "utterance": "Remove all objects from array b inside object a where attribute x contains the letter z.",
    "expressions": [
      ".a.b |= [.[] | select(.x | contains(\"z\") | not)]"
    ],
    "data": [
      {
        "input": {
          "a": {
            "b": [
              {
                "c": "1",
                "x": "aaa"
              },
              {
                "c": "2",
                "x": "aza"
              },
              {
                "c": "7",
                "x": "azb"
              }
            ]
          },
          "d": {
            "e": [
              "1"
            ],
            "f": [
              "2"
            ]
          }
        },
        "output": {
          "a": {
            "b": [
              {
                "c": "1",
                "x": "aaa"
              }
            ]
          },
          "d": {
            "e": [
              "1"
            ],
            "f": [
              "2"
            ]
          }
        }
      }
    ],
    "identifier": 55635532
  },
  {
    "context": [
      "So I have 2 json arrays, which are structurally the same, but may contain different objects or values in these objects. I want to compare them to see if they are different and what is different.",
      "now I get a true if they are identical or false if 2 jsons have differences, but I do not know what is different.",
      "What I eventually want is to get something like this:\n\n    {\n\t\t\"key\": \"IGNORE_VALIDATION_ERROR\",\n\t\t\"value\": \"true\",\n\t\t\"tags\": []\n\t}\n    {\n\t\t\"key\": \"IGNORE_VALIDATION_ERROR\",\n\t\t\"value\": \"false\",\n\t\t\"tags\": []\n\t}",
      "diff <(jq -c .[] <<<\"$bb_cfg\") <(jq -c .[] <<<\"$cd_tool_cfg\")",
      "The `-c` option will simply output a json with each array member on a separate line.",
      "The following command will give you something like you requested:\n\n    diff --old-line-format=\"%L\" --unchanged-line-format=\"\" --new-line-format=\"%L\" <(jq -c .[] <<<\"$bb_cfg\") <(jq -c .[] <<<\"$cd_tool_cfg\") | jq\n\nwill output:\n\n    {\n        \"key\": \"IGNORE_VALIDATION_ERROR\",\n        \"value\": \"true\",\n        \"tags\": []\n    }\n    {\n        \"key\": \"IGNORE_VALIDATION_ERROR\",\n        \"value\": \"false\",\n        \"tags\": []\n    }"
    ],
    "utterance": "Show all objects that differ between two arrays by outputting the complete differing objects from both arrays.",
    "expressions": [
      "jq -c .[] <<<\"$bb_cfg\"",
      "jq -c .[] <<<\"$cd_tool_cfg\""
    ],
    "data": [
      {
        "input": [
          [
            {
              "key": "IGNORE_VALIDATION_ERROR",
              "value": "true",
              "tags": []
            },
            {
              "key": "BB_CFG_REPO_NAME",
              "value": "cd-tool-cfg",
              "tags": []
            }
          ],
          [
            {
              "key": "IGNORE_VALIDATION_ERROR",
              "value": "false",
              "tags": []
            },
            {
              "key": "BB_CFG_REPO_NAME",
              "value": "cd-tool-cfg",
              "tags": []
            }
          ]
        ],
        "output": [
          {
            "key": "IGNORE_VALIDATION_ERROR",
            "value": "true",
            "tags": []
          },
          {
            "key": "IGNORE_VALIDATION_ERROR",
            "value": "false",
            "tags": []
          }
        ]
      }
    ],
    "identifier": 55606056
  },
  {
    "context": [
      "I would like to add a variable `IntendedFor` with values `scan1` and `scan2` to an existing JSON file.",
      "This is what i want the output.json file to look like:\r\n\r\n    {  \"existingjsonstuff\": \"andsoon\",  \r\n       \"IntendedFor\": [\"scan1\", \"scan2\"] \r\n    }",
      "You can just use the `+= [..]` operator to add to the array with the elements needed.\r\n\r\n    jq '.IntendedFor += [ \"scan1\", \"scan2\" ]' existing.json > output.json",
      "Eventually this code worked:\r\n\r\n    cat existing.json | jq --argjson args '[\"scan1\",\"scan2\"]' '.{\"IntededFor\"] += $args' > output.json"
    ],
    "utterance": "Add a field named IntendedFor with values scan1 and scan2 to an existing file containing other fields.",
    "expressions": [
      ".IntendedFor = [\"scan1\", \"scan2\"]",
      ".IntendedFor += [\"scan1\", \"scan2\"]",
      "jq --argjson args '[\"scan1\",\"scan2\"]' '.IntendedFor = $args'"
    ],
    "data": [
      {
        "input": {
          "existingjsonstuff": "andsoon"
        },
        "output": {
          "existingjsonstuff": "andsoon",
          "IntendedFor": [
            "scan1",
            "scan2"
          ]
        }
      }
    ],
    "identifier": 55616211
  },
  {
    "context": [
      "I'm using jq to flatten a json array to be used for sql.",
      "The above worked only while the file was small, but now I get memory errors / OS killing it as its grown larger.",
      "If I pass the --stream parameter, I get the error:",
      "`jq: error (at <stdin>:9): Cannot index array with string \"i\"`",
      "\"jq --stream -n 'foreach inputs as $pv ([[],[]]; if ($pv|length) == 2 then (.[0] |= if . == [] then . + [$pv[0][0],$pv[1]] else . + [$pv[1]] end) else [[],.[0]] end; if .[0] == [] and .[1] != [] then .[1] else empty end)' file\"",
      "def atomize(s):\n    fromstream(foreach s as $in ( {previous:null, emit: null};\n      if ($in | length == 2) and ($in|.[0][0]) != .previous and .previous != null\n      then {emit: [[.previous]], previous: $in|.[0][0]}\n      else { previous: ($in|.[0][0]), emit: null}\n      end;\n      (.emit // empty), $in) ) ;",
      "With this def, you can use your filter by prepending `atomize(inputs)` assuming you invoke jq with both the `-n` and `--stream` options.",
      "atomize(inputs)\n| to_entries[]\n| {hash: .key, val: .value[]}\n| [.hash, .val.i, .val.p, .val.l]"
    ],
    "utterance": "Flatten each object in all top-level arrays, outputting an array of [hash key, i, p, l] for each element, in a memory-efficient way suitable for large files.",
    "expressions": [
      "foreach inputs as $pv ([[],[]]; if ($pv|length) == 2 then (.[0] |= if . == [] then . + [$pv[0][0],$pv[1]] else . + [$pv[1]] end) else [[],.[0]] end; if .[0] == [] and .[1] != [] then .[1] else empty end)",
      "def atomize(s):\n  fromstream(foreach s as $in ( {previous:null, emit: null};\n    if ($in | length == 2) and ($in|.[0][0]) != .previous and .previous != null\n    then {emit: [[.previous]], previous: $in|.[0][0]}\n    else { previous: ($in|.[0][0]), emit: null}\n    end;\n    (.emit // empty), $in) ) ;\natomize(inputs)\n| to_entries[]\n| {hash: .key, val: .value[]}\n| [.hash, .val.i, .val.p, .val.l]"
    ],
    "data": [
      {
        "input": {
          "0123": [
            {
              "i": 0,
              "p": "file 1",
              "l": 100
            },
            {
              "i": 1,
              "p": "file 2",
              "l": 200
            }
          ],
          "0234": [
            {
              "i": 0,
              "p": "file 1",
              "l": 100
            },
            {
              "i": 1,
              "p": "file 2",
              "l": 200
            }
          ]
        },
        "output": [
          [
            "0123",
            0,
            "file 1",
            100
          ],
          [
            "0123",
            1,
            "file 2",
            200
          ],
          [
            "0234",
            0,
            "file 1",
            100
          ],
          [
            "0234",
            1,
            "file 2",
            200
          ]
        ]
      }
    ],
    "identifier": 55598354
  },
  {
    "context": [
      "Since a & b already exists in file2, I want to output a new object that contains only c. The values don't really matter.",
      "jq -s '. as $input | $input[0] | to_entries | map(select(.key | in($input[1]) | not)) | from_entries' temp1.json temp2.json",
      "jq -n --argfile one file1.json --argfile two file2.json '\n reduce ($two|keys_unsorted)[] as $k ($one; delpaths([[$k]]))'",
      "$one | delpaths($two|keys_unsorted|map([.]))",
      "def minus($x; $y):\n  ((($x + $y)|to_entries) - ($y|to_entries))\n  | from_entries;"
    ],
    "utterance": "Keep only the key-value pairs from the first object whose keys do not exist in the second object.",
    "expressions": [
      ". as $input | $input[0] | to_entries | map(select(.key | in($input[1]) | not)) | from_entries",
      "--argfile one file1.json --argfile two file2.json 'reduce ($two|keys_unsorted)[] as $k ($one; delpaths([[$k]]))'",
      "$one | delpaths($two|keys_unsorted|map([.]))",
      "def minus($x; $y): ((($x + $y)|to_entries) - ($y|to_entries)) | from_entries;"
    ],
    "data": [
      {
        "input": {
          "file1.json": {
            "a": "x1",
            "b": "y1",
            "c": "z1"
          },
          "file2.json": {
            "a": "x2",
            "b": "y2"
          }
        },
        "output": {
          "c": "z1"
        }
      }
    ],
    "identifier": 55622553
  },
  {
    "context": [
      "What I really want is to be able to search for any entries that have at least one \"$link\": \"randomtext1\" pair under input.",
      ".[]\n| select( any(.input[];\n              type==\"object\" and has(\"$link\") and (.[\"$link\"] | index(\"randomtext1\"))))\n| .id",
      "Of course if you require the key's value to be \"randomtext1\", you'd write .[\"$link\"] == \"randomtext1\"."
    ],
    "utterance": "Find the ids of all top-level objects that have at least one child object under input with a $link key whose value is randomtext1.",
    "expressions": [
      ".[] | select(any(.input[]; type==\"object\" and has(\"$link\") and (.[\"$link\"] == \"randomtext1\"))) | .id"
    ],
    "data": [
      {
        "input": [
          {
            "input": {
              "obj1": {
                "$link": "randomtext1"
              },
              "obj2": {
                "$link": "randomtext2"
              },
              "someotherobj": "123"
            },
            "id": "a"
          },
          {
            "input": {
              "obj3": {
                "$link": "randomtext1"
              },
              "obj4": {
                "$link": "randomtext2"
              }
            },
            "id": "b"
          }
        ],
        "output": [
          "a",
          "b"
        ]
      }
    ],
    "identifier": 55662024
  },
  {
    "context": [
      "I want to print all the string in the array delimited with comma",
      "My expected results is\n\n    [ \"afrid.google.com\", \"farid.google.com\" ]",
      "Use [tag:jq].\n```\n$ jq -Rc '. / \" \"' <<< ${hosts[*]}\n[\"afrid.google.com\",\"farid.google.com\"]\n```"
    ],
    "utterance": "Convert a bash array of hostnames into a single array where each hostname is a quoted string, separated by commas.",
    "expressions": [
      ". / \" \""
    ],
    "data": [
      {
        "input": "afrid.google.com farid.google.com",
        "output": [
          "afrid.google.com",
          "farid.google.com"
        ]
      }
    ],
    "identifier": 55695364
  },
  {
    "context": [
      "I am trying to write a bash script which parses from the nobel prize JSON file. The first argument is the year, and the second is the category.",
      "jq -cr --argjson y \"$1\" --arg c \"$2\" \\\n  '.prizes[] | select(.category == $c)| select(.year == $y )'",
      "...has no output, whereas it should output a single line with\n{\"category\":\"physics\",\"year\":\"2000\"}",
      "However, with only the category coming from a variable, it works:\n\nset -- physics  # set $1 to physics\njq -cr --arg c \"$1\" \\\n  '.prizes[] | select(.category == $c)| select(.year == \"2000\" )'",
      "Evidently in the JSON file, the year is a string, so you should use --arg y $YEAR or --arg y \"$YEAR\".",
      "With the shell variable YEAR set to a value such as 2000, the effect of --argjson y \"$YEAR\" is to set the jq variable $y to an integer:",
      "$ jq -n --argjson y \"2000\" '$y|type'\n\"number\""
    ],
    "utterance": "Select all entries where category equals physics and year equals 2000, with both values supplied by variables.",
    "expressions": [
      ".prizes[] | select(.category == $c) | select(.year == $y)"
    ],
    "data": [
      {
        "input": {
          "prizes": [
            {
              "category": "math",
              "year": "1999"
            },
            {
              "category": "physics",
              "year": "2000"
            }
          ]
        },
        "output": {
          "category": "physics",
          "year": "2000"
        }
      }
    ],
    "identifier": 55671522
  },
  {
    "context": [
      "You can use jq to do this along the following lines:\r\n\r\n    jq -cr '\"\\(.ps)\\t\\(.)\"'\r\n",
      "Now you can easily sort the lines, e.g. using `sort`; and then use e.g. `cut` to strip the .ps field.\r\n",
      "This approach creates two columns that are tab separated. The first column contains the values used for sorting. The second is the complete JSON in base64 format.",
      "After sorting we get the second column and base64 decode.",
      "gzcat sth.json.gz | \\\r\n  | jq -cr '[(. | .ps | @text), (. | @base64)] | @tsv' \\ # Create a TSV where the first column contains the value that should be sorted on."
    ],
    "utterance": "Sort a newline-delimited file by the ps field, without loading the entire file into memory.",
    "expressions": [
      "jq -cr '\"\\(.ps)\\t\\(.)\"'",
      "jq -cr '[(. | .ps | @text), (. | @base64)] | @tsv'"
    ],
    "data": [
      {
        "input": [
          {
            "ps": "abc",
            "x": 0
          },
          {
            "ps": "def",
            "x": 1
          },
          {
            "ps": "abc",
            "x": 2
          }
        ],
        "output": [
          {
            "ps": "abc",
            "x": 0
          },
          {
            "ps": "abc",
            "x": 2
          },
          {
            "ps": "def",
            "x": 1
          }
        ]
      }
    ],
    "identifier": 55712633
  },
  {
    "context": [
      "The `Alliance_id` is not correct. The correct id is:\n```\n774615702811599864\n```",
      "Using `tostring` is not going to help, because `tostring` only gets to see the number **after** the jq parser has read the input.",
      "If you wish to use an officially released version of jq, then the only available \"workaround\" will be to change the number in the JSON source to a string."
    ],
    "utterance": "Extract the precise alliance_id value, preserving its full numeric precision, even when it exceeds the standard number limit.",
    "expressions": [
      ".starbase_detailed_scan.owner_alliance_id"
    ],
    "data": [
      {
        "input": {
          "starbase_detailed_scan": {
            "last_update_time": "2018-12-23T19:26:24",
            "owner_name": "Hamita40",
            "owner_alliance_id": 774615702811599864,
            "num_drydocks": 3,
            "owner_level": 19,
            "num_defence_platforms": 3,
            "player_shield": {
              "triggered_on": "0001-01-01T00:00:00",
              "expiry_time": "0001-01-01T00:00:00"
            },
            "resources": {
              "2325683920": 183649,
              "743985951": 22459,
              "2614028847": 7074
            },
            "owner_user_id": "a2588903decc455283c88508f6a7fedf",
            "defense_rating": 25200
          }
        },
        "output": 774615702811599864
      }
    ],
    "identifier": 55689032
  },
  {
    "identifier": 55764974
  },
  {
    "context": [
      "The script given in the question generates (and executes) the following shell commands:",
      "find . -path ./node_modules/bootstrap/* -name bootstrap.min.css | xargs -I{} cp -fa {} public/css/",
      "find . -path ./node_modules/bootstrap/* -name bootstrap.min.js | xargs -I{} cp -fa {} public/js/",
      "find . -path ./node_modules/jquery/* -name jquery.min.js | xargs -I{} cp -fa {} public/js/",
      "These commands can be generated with just one invocation of jq using the following jq program:",
      "def construct:\n  (.value | to_entries[] | \"-name \\(.value[0]) | xargs -I{} cp -fs {} public/\\(.key)/\") as $s\n  | \"find . -path ./node_modules/\\(.key)/* \" + $s ;\n\n.[][]\n| to_entries[]\n| construct"
    ],
    "utterance": "Generate shell commands to copy specified files from npm packages' subfolders into target public subdirectories, using a configuration that maps package and subdirectory names to lists of filenames.",
    "expressions": [
      "def construct:\n  (.value | to_entries[] | \"-name \\(.value[0]) | xargs -I{} cp -fs {} public/\\(.key)/\") as $s\n  | \"find . -path ./node_modules/\\(.key)/* \" + $s ;\n\n.[][]\n| to_entries[]\n| construct"
    ],
    "data": [
      {
        "input": {
          "public": [
            {
              "bootstrap": {
                "js": [
                  "bootstrap.min.js"
                ],
                "css": [
                  "bootstrap.min.css"
                ]
              }
            },
            {
              "jquery": {
                "js": [
                  "jquery.min.js"
                ]
              }
            }
          ]
        },
        "output": [
          "find . -path ./node_modules/bootstrap/* -name bootstrap.min.css | xargs -I{} cp -fs {} public/css/",
          "find . -path ./node_modules/bootstrap/* -name bootstrap.min.js | xargs -I{} cp -fs {} public/js/",
          "find . -path ./node_modules/jquery/* -name jquery.min.js | xargs -I{} cp -fs {} public/js/"
        ]
      }
    ],
    "identifier": 55730360
  },
  {
    "context": [
      "How can I filter if now the key \"$link\" and its value \"randomtext1\" belong to an array?",
      "I am hoping to find both a and b with \"randomtext1\" keyword but only got b with the same filter from the previous case after obj1 and obj2 have been \"shielded/masked\" by the array brackets in the example json file.",
      "Simply add an \"or\" to cover the new possibility:",
      ".[] | select( any(.input[];\n                  (type==\"object\" and (has(\"$link\") and (.[\"$link\"]==\"randomtext1\")))\n                  or (type==\"array\" and any(.[];\n                                            type == \"object\" and (has(\"$link\") and (.[\"$link\"]==\"randomtext1\")))) ))\n    |.id",
      "def relevant($txt):\n  type == \"object\" and has(\"$link\") and (.[\"$link\"]==$txt);\n  \n.[]\n| select( any(.input[];\n              relevant(\"randomtext1\")\n              or (type==\"array\" and any(.[]; relevant(\"randomtext1\"))) ))\n|.id"
    ],
    "utterance": "Find the id values of all top-level objects where any value in the input object, or any object within an array in input, has a key $link with value randomtext1.",
    "expressions": [
      ".[] | select( any(.input[]; (type==\"object\" and (has(\"$link\") and (.[\"$link\"]==\"randomtext1\"))) or (type==\"array\" and any(.[]; type == \"object\" and (has(\"$link\") and (.[\"$link\"]==\"randomtext1\")))) )) | .id",
      "def relevant($txt): type == \"object\" and has(\"$link\") and (.[\"$link\"]==$txt); .[] | select( any(.input[]; relevant(\"randomtext1\") or (type==\"array\" and any(.[]; relevant(\"randomtext1\"))) )) | .id"
    ],
    "data": [
      {
        "input": [
          {
            "input": {
              "obj1": [
                {
                  "$link": "randomtext1"
                }
              ],
              "obj2": [
                {
                  "$link": "randomtext2"
                }
              ],
              "someotherobj": "123"
            },
            "id": "a"
          },
          {
            "input": {
              "obj3": {
                "$link": "randomtext1"
              },
              "obj4": {
                "$link": "randomtext2"
              }
            },
            "id": "b"
          }
        ],
        "output": [
          "a",
          "b"
        ]
      }
    ],
    "identifier": 55698554
  },
  {
    "context": [
      "We will use the --arg flag to reference our bash variable and set the new value for our field",
      "`cat distconfig.json | jq --arg TARGET_ID $TARGET_ID '.DefaultCacheBehavior.TargetOriginId = $TARGET_ID' > tmp.json && mv tmp.json distconfig.json`"
    ],
    "utterance": "Set the value of DefaultCacheBehavior.TargetOriginId to a shell variable containing the new string.",
    "expressions": [
      "jq --arg TARGET_ID \"$TARGET_ID\" '.DefaultCacheBehavior.TargetOriginId = $TARGET_ID'"
    ],
    "identifier": 55770671
  },
  {
    "context": [
      "And this is the format I am attempting to get out:\r\n\r\n```\r\nlocationa serviceA 5.2.0.2\r\nlocationa serviceB 4.19.0.5\r\nlocationb serviceA 5.2.0.2\r\nlocationb serviceB 4.19.0.5\r\nlocationb serviceC 1.0.0.1\r\n```",
      "you can concatenate strings using `+` operator:\r\n```\r\njq -r '.[]|.location+\" \"+(.services[]|.name+\" \"+.version)' file\r\nlocationa serviceA 5.2.0.2\r\nlocationa serviceB 4.19.0.5\r\nlocationb serviceA 5.2.0.2\r\nlocationb serviceB 4.19.0.5\r\nlocationb serviceC 1.0.0.1\r\n```",
      "jq -r '.[] | [.location] + (.services[] | [.name, .version]) | @tsv' input.json"
    ],
    "utterance": "List each object's location, then for each service entry, output the location, service name, and version, space-separated per line.",
    "expressions": [
      ".[] | .location + \" \" + (.services[] | .name + \" \" + .version)",
      ".[] | [.location] + (.services[] | [.name, .version]) | @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "location": "locationa",
            "services": [
              {
                "name": "serviceA",
                "version": "5.2.0.2",
                "updatedAt": "2018-04-17"
              },
              {
                "name": "serviceB",
                "version": "4.19.0.5",
                "updatedAt": "2018-04-17"
              }
            ]
          },
          {
            "location": "locationb",
            "services": [
              {
                "name": "serviceA",
                "version": "5.2.0.2",
                "updatedAt": "2018-04-17"
              },
              {
                "name": "serviceB",
                "version": "4.19.0.5",
                "updatedAt": "2018-04-17"
              },
              {
                "name": "serviceC",
                "version": "1.0.0.1",
                "updatedAt": "2018-04-17"
              }
            ]
          }
        ],
        "output": [
          "locationa serviceA 5.2.0.2",
          "locationa serviceB 4.19.0.5",
          "locationb serviceA 5.2.0.2",
          "locationb serviceB 4.19.0.5",
          "locationb serviceC 1.0.0.1"
        ]
      }
    ],
    "identifier": 55751874
  },
  {
    "context": [
      ".Aliases[] | (.AliasArn | select(contains(\":alias/aws/\") | not) )",
      "But this only pulls `AliasArn` field, `TargetKeyId` is also required. Any ideas on how to pull both fields?",
      "aws kms list-aliases |jq -r '.Aliases[] |select (.AliasArn |contains(\":alias/aws/\") | not) | \"AliasArn: \\(.AliasArn)\\t\\tTargetKeyId: \\(.TargetKeyId)\"'",
      "aws kms list-aliases |jq -r '.Aliases[] |select (.AliasArn |contains(\":alias/aws/\") | not) | \"AliasArn: \\(.AliasArn | split(\"/\")[1])\\t\\tTargetKeyId: \\(.TargetKeyId)\"'",
      ".Aliases[]|select(.AliasArn|contains(\":alias/aws\")|not) |.AliasArn,.TargetKeyId"
    ],
    "utterance": "Get both AliasArn and TargetKeyId for all aliases where AliasArn does not contain ':alias/aws/'.",
    "expressions": [
      ".Aliases[]|select(.AliasArn|contains(\":alias/aws/\")|not) | .AliasArn, .TargetKeyId",
      ".Aliases[]|select(.AliasArn|contains(\":alias/aws/\")|not) | {AliasArn, TargetKeyId}",
      ".Aliases[]|select(.AliasArn|contains(\":alias/aws/\")|not) | \"AliasArn: \\(.AliasArn)\\t\\tTargetKeyId: \\(.TargetKeyId)\""
    ],
    "data": [
      {
        "input": {
          "Aliases": [
            {
              "AliasName": "alias/ab1",
              "AliasArn": "arn:aws:kms:eu-west-1:123:alias/key1",
              "TargetKeyId": "66"
            },
            {
              "AliasName": "alias/ab2",
              "AliasArn": "arn:aws:kms:eu-west-1:123:alias/key2",
              "TargetKeyId": "77"
            },
            {
              "AliasName": "alias/ab3",
              "AliasArn": "arn:aws:kms:eu-west-1:123:alias/key3",
              "TargetKeyId": "88"
            },
            {
              "AliasName": "alias/ab4",
              "AliasArn": "arn:aws:kms:eu-west-1:123:alias/aws/key4",
              "TargetKeyId": "99"
            }
          ]
        },
        "output": [
          {
            "AliasArn": "arn:aws:kms:eu-west-1:123:alias/key1",
            "TargetKeyId": "66"
          },
          {
            "AliasArn": "arn:aws:kms:eu-west-1:123:alias/key2",
            "TargetKeyId": "77"
          },
          {
            "AliasArn": "arn:aws:kms:eu-west-1:123:alias/key3",
            "TargetKeyId": "88"
          }
        ]
      }
    ],
    "identifier": 55754060
  },
  {
    "context": [
      "Does not work",
      "jq --arg host \"foo.bar\" --arg port \"8082\" --arg id \"123\" '.[] | select((.hostname==$host) and (.targetPort==$port)).serviceId = $id' <<<'${JSON}' | jq -s",
      "Variables passed to jq using `--arg` are all converted to string, you need to use `--argjson` to pass integers.",
      "jq --arg host \"foo.bar\" --argjson port \"8082\" --arg id \"123\" '.[] | select((.hostname==$host) and (.targetPort==$port)).serviceId = $id' <<<'${JSON}' | jq -s",
      "As a sidenote, you don't need to call jq twice, just use `map`.",
      "jq 'map(select(.hostname==$host and .targetPort==$port).serviceId=$id)' --arg host \"foo.bar\" --argjson port 8082 --arg id \"123\" <<<'$JSON'"
    ],
    "utterance": "Update the serviceId field to \"123\" for objects where hostname is \"foo.bar\" and targetPort is 8082, using variables for these values.",
    "expressions": [
      "jq --arg host \"foo.bar\" --argjson port 8082 --arg id \"123\" 'map(select(.hostname==$host and .targetPort==$port).serviceId=$id)'"
    ],
    "data": [
      {
        "input": [
          {
            "type": "portRule",
            "hostname": "fizz.buzz",
            "protocol": "https",
            "serviceId": "1s1495",
            "sourcePort": 443,
            "targetPort": 80
          },
          {
            "type": "portRule",
            "hostname": "foo.bar",
            "serviceId": "1s1499",
            "sourcePort": 443,
            "targetPort": 8082
          }
        ],
        "output": [
          {
            "type": "portRule",
            "hostname": "fizz.buzz",
            "protocol": "https",
            "serviceId": "1s1495",
            "sourcePort": 443,
            "targetPort": 80
          },
          {
            "type": "portRule",
            "hostname": "foo.bar",
            "serviceId": "123",
            "sourcePort": 443,
            "targetPort": 8082
          }
        ]
      }
    ],
    "identifier": 55768086
  },
  {
    "context": [
      "I am trying to write a new json file. I want to define multiple variables then set them with piping to different properties in the new json file.",
      "This works with just one variable: --arg NAME VALUE pattern, but when I add in a second arg and use piping `jq ... 'x1 = y1 | x2 = y2, e.g.` it breaks.",
      "pipe should be **inside the filter**. and, consider using assignment operator to shorten your code:",
      "jq --arg dnb \"$DOMAIN_NAME_BUILT\" \\\n   --arg origin \"$DOMAIN_ID_BUILT\" \\\n   '.Origins.Items[0] |= ( .DomainName = $dnb | .Id = $origin )' \\"
    ],
    "utterance": "Set multiple properties (.DomainName and .Id) of the same object to different values provided as variables.",
    "expressions": [
      ".Origins.Items[0] |= ( .DomainName = $dnb | .Id = $origin )"
    ],
    "identifier": 55778231
  },
  {
    "context": [
      "I am trying to read my `distconfig.json` file and set the properties with the above variables.",
      "jq '.Origins.Items[0].DomainName = \"$DOMAIN_NAME_BUILT\"' distconfig.json > \"$tmp\" && mv \"$tmp\" distconfig.json",
      "The command is working, but it is passing in the variable as a string to my new json file. So when I view the property in the new created json file it is being saved as `\"$DOMAIN_NAME_BUILT\"` instead of `stag5.example.io.s3-website.us-east-2.amazonaws.com`",
      "How can I instead of passing the string pass the variable for $DOMAIN_NAME_BUILT and write it to the new json file",
      "Use the `--argjson` option instead of parameter interpolation.",
      "jq --argjson dnb \"$DOMAIN_NAME_BUILT\" \\\n    '.Origins.Items[0].DomainName = $dnb' distconfig.json > \"$tmp\" &&\n  mv \"$tmp\" distconfig.json",
      "(Your immediate issue is that parameter expansion doesn't occur inside single quotes, but building a static filter that takes an argument is safer than building a filter dynamically.)"
    ],
    "utterance": "Update the value of the .Origins.Items[0].DomainName property to the value of a shell variable DOMAIN_NAME_BUILT",
    "expressions": [
      "jq --arg dnb \"$DOMAIN_NAME_BUILT\" '.Origins.Items[0].DomainName = $dnb' distconfig.json > \"$tmp\" && mv \"$tmp\" distconfig.json"
    ],
    "identifier": 55777505
  },
  {
    "context": [
      "Save curl response to a variable json with -i flag",
      "however, performing a jq filter will yields... parse error: Invalid numeric literal at line 1, column 9",
      "> remove the -i flag"
    ],
    "utterance": "Filter a property from the response of a curl command using jq when the response was previously saved with and without the -i flag.",
    "expressions": [
      "echo $json | jq '.property'"
    ],
    "identifier": 55791097
  },
  {
    "context": [
      "I used jq , and used the below command:",
      "jq -s add file1.json file2.json > Output.json",
      "That said, I believe you can use jq -s '.[0] * .[1]' file1 file2 to merge two JSON files"
    ],
    "utterance": "Merge two files so that their top-level objects are combined using the update operator *.",
    "expressions": [
      "jq -s '.[0] * .[1]' file1.json file2.json"
    ],
    "identifier": 55807612
  },
  {
    "context": [
      "I want to transform it, making the key of each record into a field of that record in a streaming fashion.",
      "atomize(inputs) | to_entries[] | .value + {key}",
      "def atomize(s):\n  fromstream(foreach s as $in ( {previous:null, emit: null};\n      if ($in | length == 2) and ($in|.[0][0]) != .previous and .previous != null\n      then {emit: [[.previous]], previous: ($in|.[0][0])}\n      else { previous: ($in|.[0][0]), emit: null}\n      end;\n      (.emit // empty), $in\n      ) ) ;"
    ],
    "utterance": "For each top-level key-value pair, emit an object that includes all nested data and adds the original key as a new field, using streaming processing for large input.",
    "expressions": [
      "atomize(inputs) | to_entries[] | .value + {key}"
    ],
    "data": [
      {
        "input": {
          "foo": {
            "a": 1,
            "b": 2
          },
          "bar": {
            "a": 1,
            "b": 2
          }
        },
        "output": [
          {
            "a": 1,
            "b": 2,
            "key": "foo"
          },
          {
            "a": 1,
            "b": 2,
            "key": "bar"
          }
        ]
      }
    ],
    "identifier": 55773054
  },
  {
    "context": [
      "I'm trying to get the `Name` of the most recent (by `CreationDate`) image that contains \"stable\" in its `Name`.",
      "$ jq -r '.Images | map(select(.Name | index(\"stable\"))) | max_by(.CreationDate).Name' file",
      "max_by is used because it avoids sorting and yields the element with max. `CreationDate`."
    ],
    "utterance": "Get the Name of the image with the most recent CreationDate where Name contains \"stable\".",
    "expressions": [
      ".Images | map(select(.Name | index(\"stable\"))) | max_by(.CreationDate).Name"
    ],
    "data": [
      {
        "input": {
          "Images": [
            {
              "Name": "CoreOS-alpha-1939.0.0-hvm",
              "CreationDate": "2014-12-24T23:00:48.000Z"
            },
            {
              "Name": "CoreOS-stable-522.3.0",
              "CreationDate": "2014-12-24T23:00:48.000Z"
            },
            {
              "Name": "CoreOS-stable-600.3.0",
              "CreationDate": "2019-12-24T23:00:48.000Z"
            }
          ]
        },
        "output": "CoreOS-stable-600.3.0"
      }
    ],
    "identifier": 55815888
  },
  {
    "context": [
      "but I would like to be able to index nested properties as well something like:",
      ">>> {\n  \"success\": true,\n  \"results\": {\n    \"b\": \"...\"\n  }\n}",
      "or",
      ">>> {\n  \"success\": true,\n  \"results.b\": \"...\"\n}",
      "echo '{\"success\":true, \"failure\":false, \"results\":{\"a\": \"...\", \"b\": \"...\", \"c\": \"...\"}}' | jq '{ success, \"results.b\":.results.b }'"
    ],
    "utterance": "Extract the value of the top-level key 'success' and the nested key 'results.b', outputting them as sibling keys in the result.",
    "expressions": [
      "{ success, \"results.b\": .results.b }"
    ],
    "data": [
      {
        "input": {
          "success": true,
          "failure": false,
          "results": {
            "a": "...",
            "b": "...",
            "c": "..."
          }
        },
        "output": {
          "success": true,
          "results.b": "..."
        }
      }
    ],
    "identifier": 55812342
  },
  {
    "context": [
      "Given the above input, my intended/desired output is:\r\n\r\n```none\r\nyyy1\r\nyyy2\r\n```",
      "jq -r '.tags[] | .[\"image_id\"]' <new.json",
      ".tags[] | .image_id",
      ".tags[].image_id",
      ".. | objects | select(has(\"image_id\")) | .image_id",
      ".. | .image_id? // empty"
    ],
    "utterance": "Extract all values of the key image_id from the tags array.",
    "expressions": [
      ".tags[] | .image_id",
      ".tags[].image_id",
      ".tags[] | .[\"image_id\"]",
      ".. | objects | select(has(\"image_id\")) | .image_id",
      ".. | .image_id? // empty"
    ],
    "data": [
      {
        "input": {
          "tags": [
            {
              "name": "xxx1",
              "image_id": "yyy1"
            },
            {
              "name": "xxx2",
              "image_id": "yyy2"
            }
          ]
        },
        "output": [
          "yyy1",
          "yyy2"
        ]
      }
    ],
    "identifier": 55840662
  },
  {
    "context": [
      "Now I want to **use that $i value** in a different filter, so instead of outputting 0 it outputs something like the result of this:\r\n\r\n`.edgeGroups.hasAttributeValue[] | select(.[0] == 0)`",
      "if I could understand how to use the $i in a chained filter, I think I could solve my main goal, which is to chain several filters together so that I can get all the items associated with the 71597 object - i.e.\r\n\r\n{\r\n  \"id\": 129748,\r\n  \"ns\": \"av\",\r\n  \"name\": \"Polarized\"\r\n},\r\n{\r\n  \"id\": 129898,\r\n  \"ns\": \"av\",\r\n  \"name\": \"False\"\r\n}",
      "Your jq filter could be fixed with a couple of parentheses:\r\n\r\n    (.vertices\r\n     | range(0;length) as $i\r\n     | select(.[$i].alias==\"polarized\" and .[$i].ns==\"ca\")\r\n     | $i) as $i\r\n    | .edgeGroups.hasAttributeValue[]\r\n    | select(.[0] == $i)\r\n"
    ],
    "utterance": "Return all objects in the vertices array whose indices are referenced as the second element of each pair in edgeGroups.hasAttributeValue, where the first element matches the index of the vertex with alias \"polarized\" and ns \"ca\".",
    "expressions": [
      "(.vertices | range(0;length) as $i | select(.[$i].alias==\"polarized\" and .[$i].ns==\"ca\") | $i) as $i | .edgeGroups.hasAttributeValue[] | select(.[0] == $i) | .[1] as $j | .vertices[$j]"
    ],
    "data": [
      {
        "input": {
          "vertices": [
            {
              "id": 71597,
              "ns": "ca",
              "alias": "polarized"
            },
            {
              "id": 129748,
              "ns": "av",
              "name": "Polarized"
            },
            {
              "id": 129898,
              "ns": "av",
              "name": "False"
            }
          ],
          "edgeGroups": {
            "hasAttributeValue": [
              [
                0,
                1
              ],
              [
                0,
                2
              ]
            ]
          }
        },
        "output": [
          {
            "id": 129748,
            "ns": "av",
            "name": "Polarized"
          },
          {
            "id": 129898,
            "ns": "av",
            "name": "False"
          }
        ]
      }
    ],
    "identifier": 55837980
  },
  {
    "context": [
      "looking in json, find any stack with a date further back than killdate and list stack name only if starts with HAPPY which I achieve with",
      "echo $json |jq '.StackSummaries[]' | jq -r 'select (.CreationTime>\"$killdate\") | .StackName' | awk '/^HAPPY/'",
      "I would have expected the below",
      "\"2019-04-15T14:31:42.515Z\"",
      "\"2018-01-23T15:44:48.134Z\"",
      "and once returning the stackname instead",
      "\"HAPPYHARRY123789456\"",
      "FOUND MY ANSWER WHILST WRITING THIS SO PUT IT HERE FOR OTHERS",
      "echo $json |jq '.StackSummaries[]' | jq --arg kill $killdate 'select (.CreationTime < $kill ) | .CreationTime'"
    ],
    "utterance": "List the stack names that have a CreationTime earlier than the variable killdate and where the StackName starts with 'HAPPY'.",
    "expressions": [
      ".StackSummaries[] | select(.CreationTime < $killdate and (.StackName | test(\"^HAPPY\"))) | .StackName"
    ],
    "data": [
      {
        "input": {
          "StackSummaries": [
            {
              "StackId": "arn:aws:cloudformation:eu-029e8e947a9c",
              "DriftInformation": {
                "StackDriftStatus": "NOT_CHECKED"
              },
              "TemplateDescription": "Testing - SINGLE",
              "CreationTime": "2019-04-23T15:25:22.757Z",
              "StackName": "HAPPYHARRY123456789",
              "StackStatus": "CREATE_COMPLETE"
            },
            {
              "StackId": "arn:aws:cloudformation:eu-0a4e84363f34",
              "DriftInformation": {
                "StackDriftStatus": "NOT_CHECKED"
              },
              "TemplateDescription": "Testing - SINGLE",
              "CreationTime": "2019-04-15T14:31:42.515Z",
              "StackName": "HAPPYHARRY123789456",
              "StackStatus": "CREATE_COMPLETE"
            },
            {
              "StackId": "arn:aws:cloudformation:eu-50faeb5394d2",
              "LastUpdatedTime": "2018-01-23T15:44:53.640Z",
              "TemplateDescription": "Lambda Gateway",
              "CreationTime": "2018-01-23T15:44:48.134Z",
              "StackName": "BARRYLAMBDA",
              "StackStatus": "CREATE_COMPLETE",
              "DriftInformation": {
                "StackDriftStatus": "NOT_CHECKED"
              }
            }
          ]
        },
        "output": [
          "HAPPYHARRY123789456"
        ]
      }
    ],
    "identifier": 55815623
  },
  {
    "context": [
      "grep is not the right tool for parsing JSON. Use [tag:jq] instead:",
      "$ jq -r '.response_status' RGLogin.json",
      "200",
      "$",
      "$ jq -r '.response.session_id' RGLogin.json",
      "2d48cc11ceabf28c9e92f4b677337dcd",
      "$jq -r '.response.session_id, .response_status' RGLogin.json",
      "2d48cc11ceabf28c9e92f4b677337dcd",
      "200"
    ],
    "utterance": "Extract the response_status and response.session_id values from the file RGLogin.json.",
    "expressions": [
      ".response_status",
      ".response.session_id",
      ".response.session_id, .response_status"
    ],
    "data": [
      {
        "input": {
          "response": {
            "session_id": "2d48cc11ceabf28c9e92f4b677337dcd"
          },
          "response_status": 200,
          "response_details": null
        },
        "output": [
          "2d48cc11ceabf28c9e92f4b677337dcd",
          200
        ]
      }
    ],
    "identifier": 55848752
  },
  {
    "context": [
      "I want to merge two json files on linux by using jq with group_by(.id)",
      "What I expect is",
      "{ \"id\":\"1234\", \"branch\": [\"master\", \"dev\"], \"other\": \"value\", \"arr\":[\"say\", \"one\", \"more\", \"what\"] }",
      "{ \"id\":\"102\", \"branch\": [\"master\", \"dev\"], \"arr\":[\"yes\"] }",
      "{ \"id\":\"1228\", \"branch\": \"master\" }",
      "{ \"id\":\"0806\", \"branch\": \"master\" }",
      "jq -n -f combine.jq --slurpfile f1 file1.json --slurpfile f2 file2.json",
      "INDEX( $f1[]; .id) as $d1\n| INDEX( $f2[]; .id) as $d2\n| reduce (($d1+$d2)|keys_unsorted)[] as $id\n    ({}; .[$id] = ($d1[$id] | combine($d2[$id])) )\n| .[]",
      "# Combine . with obj using aggregate/2 for shared keys whose values differ\ndef combine($obj):\n  def aggregate(a; b):\n    if (a|type) == \"array\" then\n      if (b|type) == \"array\" then a + b\n      else a + [b]\n      end\n    else\n      if (b|type) == \"array\" then [a] + b\n      else [a, b]\n      end\n    end;\n  if . == null then $obj\n  elif $obj == null then .\n  else reduce ($obj|keys_unsorted[]) as $key (.;\n         if .[$key] == $obj[$key] then . \n         else .[$key] = if has($key) and ($obj|has($key))\n                        then aggregate( .[$key]; $obj[$key] )\n                        else .[$key] + $obj[$key]\n\t\t        end\n         end )\n   end ;"
    ],
    "utterance": "Merge two files on Linux so objects with the same id have array values for keys that appear with different values, combine arrays, and preserve unique and non-overlapping keys.",
    "expressions": [
      "INDEX( $f1[]; .id) as $d1\n| INDEX( $f2[]; .id) as $d2\n| reduce (($d1+$d2)|keys_unsorted)[] as $id\n    ({}; .[$id] = ($d1[$id] | combine($d2[$id])) )\n| .[]",
      "def combine($obj):\n  def aggregate(a; b):\n    if (a|type) == \"array\" then\n      if (b|type) == \"array\" then a + b\n      else a + [b]\n      end\n    else\n      if (b|type) == \"array\" then [a] + b\n      else [a, b]\n      end\n    end;\n  if . == null then $obj\n  elif $obj == null then .\n  else reduce ($obj|keys_unsorted[]) as $key (.;\n         if .[$key] == $obj[$key] then . \n         else .[$key] = if has($key) and ($obj|has($key))\n                        then aggregate( .[$key]; $obj[$key] )\n                        else .[$key] + $obj[$key]\n\t\t        end\n         end )\n   end ;"
    ],
    "data": [
      {
        "input": [
          {
            "id": "1234",
            "branch": "master",
            "arr": [
              "say",
              "one",
              "more"
            ]
          },
          {
            "id": "102",
            "branch": "master",
            "arr": [
              "yes"
            ]
          },
          {
            "id": "1228",
            "branch": "master"
          }
        ]
      },
      {
        "input": [
          {
            "id": "1234",
            "branch": "dev",
            "other": "value",
            "arr": [
              "what"
            ]
          },
          {
            "id": "102",
            "branch": "dev"
          },
          {
            "id": "0806",
            "branch": "master"
          }
        ]
      },
      {
        "output": [
          {
            "id": "1234",
            "branch": [
              "master",
              "dev"
            ],
            "other": "value",
            "arr": [
              "say",
              "one",
              "more",
              "what"
            ]
          },
          {
            "id": "102",
            "branch": [
              "master",
              "dev"
            ],
            "arr": [
              "yes"
            ]
          },
          {
            "id": "1228",
            "branch": "master"
          },
          {
            "id": "0806",
            "branch": "master"
          }
        ]
      }
    ],
    "identifier": 55806642
  },
  {
    "identifier": 55888111
  },
  {
    "context": [
      "I want to remove the `RTSMSnapshotID` key value pair entirely as part of my bash script.",
      "jq: error (at <filename>): Cannot index array with string \"RTSMSnapshotID\"",
      "jq '[ .[] | select(.ParameterKey != \"RTSMSnapshotID\") ]'",
      "jq 'map(select(.ParameterKey != \"RTSMSnapshotID\"))'"
    ],
    "utterance": "Remove all objects from the list where ParameterKey is equal to RTSMSnapshotID.",
    "expressions": [
      "[ .[] | select(.ParameterKey != \"RTSMSnapshotID\") ]",
      "map(select(.ParameterKey != \"RTSMSnapshotID\"))"
    ],
    "data": [
      {
        "input": [
          {
            "ParameterKey": "RTSMMinSize",
            "ParameterValue": "1"
          },
          {
            "ParameterKey": "RTSMReplicateDB",
            "ParameterValue": "false"
          },
          {
            "ParameterKey": "RTSMSnapshotID",
            "ParameterValue": "snapID"
          },
          {
            "ParameterKey": "RTSMEMAIL",
            "ParameterValue": ""
          }
        ],
        "output": [
          {
            "ParameterKey": "RTSMMinSize",
            "ParameterValue": "1"
          },
          {
            "ParameterKey": "RTSMReplicateDB",
            "ParameterValue": "false"
          },
          {
            "ParameterKey": "RTSMEMAIL",
            "ParameterValue": ""
          }
        ]
      }
    ],
    "identifier": 55857004
  },
  {
    "context": [
      "Required output: I need to retrieve the value of my environment variable as the last column in my output csv file",
      "jq -r --arg repovar \"$line\" '.data.Layer.Features[] | .Name + \", \" + .Version + \", \" + $repovar' severity.json",
      "repovar='qweqe'; jq -r --arg repovar \"$repovar\" '.data.Layer| .Features[] | \"\\(.Name), \\(.Version), \\($repovar)\"' tmp.json"
    ],
    "utterance": "Output each feature's name and version along with the value of an environment variable, as the last column in each CSV line.",
    "expressions": [
      ".data.Layer.Features[] | .Name + \", \" + .Version + \", \" + $repovar",
      ".data.Layer| .Features[] | \"\\(.Name), \\(.Version), \\($repovar)\""
    ],
    "data": [
      {
        "input": {
          "status": "scanned",
          "data": {
            "Layer": {
              "IndexedByVersion": 3,
              "Features": [
                {
                  "Name": "elfutils",
                  "Version": "0.168-1",
                  "Vulnerabilities": [
                    {
                      "NamespaceName": "debian:9",
                      "Severity": "Medium",
                      "Name": "CVE-2016-2779"
                    }
                  ]
                }
              ]
            }
          }
        },
        "output": "elfutils, 0.168-1, Reponame1"
      }
    ],
    "identifier": 55876313
  },
  {
    "context": [
      "I want to retrieve the value of the byte count i.e. byteCount. The result should be 480.",
      "But below is the output that I get:\ncat queue.json | jq -r '.byteCount'\nnull",
      "You need to specify the full path:\n$ jq '.listingRequest.queueSize.byteCount' file.json\n480",
      "An alternative to specifying the full path is to use `..`, e.g.\n    $ jq '.. | .byteCount? // empty' queue.json \n    480"
    ],
    "utterance": "Extract the value of byteCount, which is 480, from within listingRequest.queueSize.",
    "expressions": [
      ".listingRequest.queueSize.byteCount",
      ".. | .byteCount? // empty"
    ],
    "data": [
      {
        "input": {
          "listingRequest": {
            "id": "016a1050-82dc-1262-cc9b-4baf3e0b7123",
            "uri": "http://localhost:9090/nifi-api/flowfile-queues/016a104a-82dc-1262-7d78-d84a704abfbf/listing-requests/016a1050-82dc-1262-cc9b-4baf3e0b7123",
            "submissionTime": "04/28/2019 19:40:58.593 UTC",
            "lastUpdated": "19:40:58 UTC",
            "percentCompleted": 0,
            "finished": false,
            "maxResults": 100,
            "state": "Waiting for other queue requests to complete",
            "queueSize": {
              "byteCount": 480,
              "objectCount": 20
            },
            "sourceRunning": false,
            "destinationRunning": false
          }
        },
        "output": 480
      }
    ],
    "identifier": 55894052
  },
  {
    "context": [
      "I need parent keys along with one key-value pair from the child array",
      "Which ever value has latest date in it , will be the resulting key-value pair",
      "Need to generate a csv out of that result",
      "Parse dates using `strptime` and assign the result to *value*s, thus you can get the latest *attendance* using `max_by`. Convert the *value* to seconds since Epoch using `mktime`, substract it from *now*, divide by 24 * 60 * 60 to get number of days since.",
      "`$ jq -r '\ndef days_since:\n  (now - .) / 86400 | floor;\n.students[]\n| [ .name, .class ] +\n  ( .attendance\n    | map(.value |= strptime(\"%d-%b-%Y\"))\n    | max_by(.value)\n    | [ .key, \"\\(.value | mktime | days_since) days ago\" ]\n  ) +\n  [ .teacher + \".\" + .class ]\n| @tsv' file\nName1   parentClass1    class1  148 days ago    teacher1.parentClass1\nName2   parentClass2    class2  144 days ago    teacher2.parentClass2"
    ],
    "utterance": "For each student, output their name, class, the key and value of the attendance record with the most recent date, and a summary column combining teacher and class; dates should be shown as 'N days ago'.",
    "expressions": [
      "def days_since:\n  (now - .) / 86400 | floor;\n.students[]\n| [ .name, .class ] +\n  ( .attendance\n    | map(.value |= strptime(\"%d-%b-%Y\"))\n    | max_by(.value)\n    | [ .key, \"\\(.value | mktime | days_since) days ago\" ]\n  ) +\n  [ .teacher + \".\" + .class ]\n| @tsv"
    ],
    "data": [
      {
        "input": {
          "students": [
            {
              "name": "Name1",
              "class": "parentClass1",
              "teacher": "teacher1",
              "attendance": [
                {
                  "key": "class1",
                  "value": "01-DEC-2018"
                },
                {
                  "key": "class1",
                  "value": "28-Nov-2018"
                },
                {
                  "key": "class1",
                  "value": "26-Oct-2018"
                }
              ]
            },
            {
              "name": "Name2",
              "class": "parentClass2",
              "teacher": "teacher2",
              "attendance": [
                {
                  "key": "class2",
                  "value": "05-DEC-2018"
                },
                {
                  "key": "class2",
                  "value": "25-Nov-2018"
                },
                {
                  "key": "class2",
                  "value": "20-Oct-2018"
                }
              ]
            }
          ]
        },
        "output": "Name1\tparentClass1\tclass1\t148 days ago\tteacher1.parentClass1\nName2\tparentClass2\tclass2\t144 days ago\tteacher2.parentClass2"
      }
    ],
    "identifier": 55888155
  },
  {
    "context": [
      "Suppose I have the following json input to the jq command:\r\n\r\n    [\r\n      {\"type\":\"dog\",  \"set\":\"foo\"},\r\n      {\"type\":\"bird\", \"set\":\"bar\"},\r\n      {\"type\":\"cat\",  \"set\":\"blaz\"},\r\n      {\"type\":\"fish\", \"set\":\"mor\"}\r\n    ]\r\n\r\nI know that there is an element in this array whose `type` is \"bird\", in this case, the second element.  But I want its next (or previous) sibling, that is, the element after (before) it, in this case, the third (first) element.  How can I get it in jq?\r\n\r\nAlso, I have another question: If the matched element (that is, the element whose value of `type` I know) is the last one in the array, I want it to get the first one as next (that is, cycle through the array) instead of returning nothing. The same whether the matched element is the first one (then I want to get the last element).",
      "For the sake of specificity, let's suppose you want to extract the the `(before, focus, after)` triple as an array, where `before` and `after` wrap around as described. For simplicity, let's also suppose the source array is of length at least 2.",
      "Now we have only to find the index, and use it:\r\n\r\n    (map(.type) | index(\"bird\")) as $i\r\n    | if $i then triple($i) else empty end",
      "    def triple($i):\r\n      if $i == 0 then [last] + .[0:2]\r\n      elif $i == (length-1) then .[$i-1: $i+2] + [first]\r\n      else .[$i-1: $i+2]\r\n      end;"
    ],
    "utterance": "Find the next (or previous) element in an array whose 'type' property matches a given value, wrapping around the array if at the end or start.",
    "expressions": [
      "def next_elem(target): (map(.type) | index(target)) as $i | if $i == null then empty else .[($i+1)%length] end",
      "def prev_elem(target): (map(.type) | index(target)) as $i | if $i == null then empty else .[($i-1+length)%length] end"
    ],
    "data": [
      {
        "input": [
          {
            "type": "dog",
            "set": "foo"
          },
          {
            "type": "bird",
            "set": "bar"
          },
          {
            "type": "cat",
            "set": "blaz"
          },
          {
            "type": "fish",
            "set": "mor"
          }
        ],
        "output": {
          "type": "cat",
          "set": "blaz"
        }
      }
    ],
    "identifier": 55896344
  },
  {
    "context": [
      "and we want to keep only a subset of the keys such as `k1`",
      "What operation do we have to do to get the following output?",
      "[ {\"k1\": \"v1\"}, {\"k1\": \"v1\"}, {\"k1\": \"v1\"} ]",
      "Use `map`, it applies a filter to all elements of an array.",
      "`$ jq 'map({k1})' file`"
    ],
    "utterance": "Keep only the key k1 in each object of the array, preserving the array structure.",
    "expressions": [
      "map({k1})"
    ],
    "data": [
      {
        "input": [
          {
            "k1": "v1",
            "k2": "v2"
          },
          {
            "k1": "v1",
            "k2": "v2"
          },
          {
            "k1": "v1",
            "k2": "v2"
          }
        ],
        "output": [
          {
            "k1": "v1"
          },
          {
            "k1": "v1"
          },
          {
            "k1": "v1"
          }
        ]
      }
    ],
    "identifier": 55921743
  },
  {
    "context": [
      "i want to merge these two json arrays into one.",
      "If you need to just merge the two arrays into one, you can use\n\n    jq '[.[0][], .[1][]]' <<< \"[$local, $org]\"",
      "Use `+`, not `*`:\n\n    ...\n    echo $(jq -s '.[0] + .[1]' <<EOF\n    $j1\n    $j2\n    EOF\n    )",
      "produces:\n\n    [ { \"account_id\": \"01C\", \"id\": \"0XVWKCFV6P9CA5\" }, { \"account_id\": \"CSDTHQ\", \"id\": \"631QGYBNSF\" }, { \"account_id\": \"BJPKWSH\", \"id\": \"15BS0XP4F91V6YH4G0PV\" }, { \"account_id\": \"01BKK44V5F6A1FKH60Q0ANX9JX\", \"id\": \"01BKK44V7\" } ]"
    ],
    "utterance": "Combine two arrays of objects into a single array containing all objects from both arrays.",
    "expressions": [
      "jq -s '.[0] + .[1]'",
      "jq '[.[0][], .[1][]]'"
    ],
    "data": [
      {
        "input": [
          [
            {
              "account_id": "01C",
              "id": "0XVWKCFV6P9CA5"
            },
            {
              "account_id": "CSDTHQ",
              "id": "631QGYBNSF"
            }
          ],
          [
            {
              "account_id": "BJPKWSH",
              "id": "15BS0XP4F91V6YH4G0PV"
            },
            {
              "account_id": "01BKK44V5F6A1FKH60Q0ANX9JX",
              "id": "01BKK44V7"
            }
          ]
        ],
        "output": [
          {
            "account_id": "01C",
            "id": "0XVWKCFV6P9CA5"
          },
          {
            "account_id": "CSDTHQ",
            "id": "631QGYBNSF"
          },
          {
            "account_id": "BJPKWSH",
            "id": "15BS0XP4F91V6YH4G0PV"
          },
          {
            "account_id": "01BKK44V5F6A1FKH60Q0ANX9JX",
            "id": "01BKK44V7"
          }
        ]
      }
    ],
    "identifier": 55901703
  },
  {
    "context": [
      "I have the following JSON output. I would like the output to be grouped by the common TZ.",
      "I could not find a way to make this work with group_by and map functions.",
      "You probably want the following or a variation thereof :",
      "jq --slurp 'group_by(.TZ) | map({TZ:.[0].TZ, values:map({TN, TNN})})'"
    ],
    "utterance": "Group all objects by the value of the TZ key, outputting for each TZ a list of its TN and TNN values.",
    "expressions": [
      "group_by(.TZ) | map({TZ:.[0].TZ, values:map({TN, TNN})})"
    ],
    "data": [
      {
        "input": [
          {
            "TZ": "5f105439-a0a7-4134-9e98-87553d434b35",
            "TN": "4c4c4544-0046-3310-8056-b2c04f433432",
            "TNN": "a2331"
          },
          {
            "TZ": "5f105439-a0a7-4134-9e98-87553d434b35",
            "TN": "4c4c4544-0030-5110-8051-b3c04f433432",
            "TNN": "a2332"
          },
          {
            "TZ": "5f105439-a0a7-4134-9e98-87553d434b35",
            "TN": "4c4c4544-0030-5210-8054-b3c04f433432",
            "TNN": "a2437"
          },
          {
            "TZ": "5f105439-a0a7-4134-9e98-87553d434b35",
            "TN": "4c4c4544-0030-5110-8052-b3c04f433432",
            "TNN": "a2438"
          },
          {
            "TZ": "5f105439-a0a7-4134-9e98-87553d434b35",
            "TN": "4c4c4544-0030-5210-8050-b3c04f433432",
            "TNN": "a2439"
          },
          {
            "TZ": "5f105439-a0a7-4134-9e98-87553d434b35",
            "TN": "4c4c4544-0046-3310-8053-b2c04f433432",
            "TNN": "a2440"
          },
          {
            "TZ": "8dc3bff5-09b2-4518-81e8-39a8136f885f",
            "TN": "4c4c4544-0046-3310-8056-b2c04f433432",
            "TNN": "a2331"
          },
          {
            "TZ": "8dc3bff5-09b2-4518-81e8-39a8136f885f",
            "TN": "4c4c4544-0030-5110-8051-b3c04f433432",
            "TNN": "a2332"
          },
          {
            "TZ": "8dc3bff5-09b2-4518-81e8-39a8136f885f",
            "TN": "4c4c4544-0030-5210-8054-b3c04f433432",
            "TNN": "a2437"
          },
          {
            "TZ": "8dc3bff5-09b2-4518-81e8-39a8136f885f",
            "TN": "4c4c4544-0030-5110-8052-b3c04f433432",
            "TNN": "a2438"
          },
          {
            "TZ": "8dc3bff5-09b2-4518-81e8-39a8136f885f",
            "TN": "4c4c4544-0030-5210-8050-b3c04f433432",
            "TNN": "a2439"
          },
          {
            "TZ": "8dc3bff5-09b2-4518-81e8-39a8136f885f",
            "TN": "4c4c4544-0046-3310-8053-b2c04f433432",
            "TNN": "a2440"
          }
        ],
        "output": [
          {
            "TZ": "5f105439-a0a7-4134-9e98-87553d434b35",
            "values": [
              {
                "TN": "4c4c4544-0046-3310-8056-b2c04f433432",
                "TNN": "a2331"
              },
              {
                "TN": "4c4c4544-0030-5110-8051-b3c04f433432",
                "TNN": "a2332"
              },
              {
                "TN": "4c4c4544-0030-5210-8054-b3c04f433432",
                "TNN": "a2437"
              },
              {
                "TN": "4c4c4544-0030-5110-8052-b3c04f433432",
                "TNN": "a2438"
              },
              {
                "TN": "4c4c4544-0030-5210-8050-b3c04f433432",
                "TNN": "a2439"
              },
              {
                "TN": "4c4c4544-0046-3310-8053-b2c04f433432",
                "TNN": "a2440"
              }
            ]
          },
          {
            "TZ": "8dc3bff5-09b2-4518-81e8-39a8136f885f",
            "values": [
              {
                "TN": "4c4c4544-0046-3310-8056-b2c04f433432",
                "TNN": "a2331"
              },
              {
                "TN": "4c4c4544-0030-5110-8051-b3c04f433432",
                "TNN": "a2332"
              },
              {
                "TN": "4c4c4544-0030-5210-8054-b3c04f433432",
                "TNN": "a2437"
              },
              {
                "TN": "4c4c4544-0030-5110-8052-b3c04f433432",
                "TNN": "a2438"
              },
              {
                "TN": "4c4c4544-0030-5210-8050-b3c04f433432",
                "TNN": "a2439"
              },
              {
                "TN": "4c4c4544-0046-3310-8053-b2c04f433432",
                "TNN": "a2440"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 55587279
  },
  {
    "context": [
      "depending on the 'repo' I need to be able to parse from the properties array all 'key' & values and associated with the repository.  For example the repo \"libs-production-local\" would need to parse out any properties key with 'prod' in the string and its associated date value.",
      "jq -r '[ .results[].properties[] | select(.key | contains(\"prod\")) ]'",
      "This grabs all key-value pairs from _each_ result's properties array.  It then selects those that contain \"prod\" in the key, and returns an array of those keys and values.  Given your example input from above, this is the return value:"
    ],
    "utterance": "Extract all property key-value pairs whose key contains 'prod' from objects in the 'results' array with repo 'libs-production-local'.",
    "expressions": [
      ".results[] | select(.repo==\"libs-production-local\") | .properties[] | select(.key | contains(\"prod\"))"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "repo": "libs-production-local",
              "path": "com/company/version",
              "name": "sql.21.tar",
              "type": "file",
              "size": "40123",
              "created": "date",
              "created_by": "someone",
              "modified": "date",
              "modified_by": "someone",
              "updated": "date",
              "depth": 4,
              "actual_md5": "asdflsdf23a4324234",
              "orginal_sha1": "sadlkfjsdklfjsadf",
              "properties": [
                {
                  "key": "deploy.uat",
                  "value": "2018-09-23"
                },
                {
                  "key": "deploy.prod.TLE",
                  "value": "2018-10-20"
                },
                {
                  "key": "deploy.prodXYZ",
                  "value": "2018-10-20"
                },
                {
                  "key": "deploy.prodPDQ",
                  "value": "2018-10-20"
                },
                {
                  "key": "deploy.prod.ABC",
                  "value": "2018-10-21"
                },
                {
                  "key": "businessUnit.name",
                  "value": "IndivdualName"
                },
                {
                  "key": "deploy.qa.ser2",
                  "value": "2018-10-20"
                },
                {
                  "key": "deploy.qa.ser1",
                  "value": "2018-11-23"
                },
                {
                  "key": "build.timestamp",
                  "value": "1510850899004"
                }
              ],
              "virtual_repos": [
                "libs-production "
              ]
            },
            {
              "repo": "libs-production-local",
              "path": "com/company/version",
              "name": "sql.22.tar",
              "type": "file",
              "size": "40123",
              "created": "date",
              "created_by": "someone",
              "modified": "date",
              "modified_by": "someone",
              "updated": "date",
              "depth": 4,
              "actual_md5": "asdflsdf23a4324234",
              "orginal_sha1": "sadlkfjsdklfjsadf",
              "properties": [
                {
                  "key": "deploy.prodPDQ",
                  "value": "2018-10-22"
                },
                {
                  "key": "deploy.prodABC",
                  "value": "2018-10-20"
                },
                {
                  "key": "businessUnit.name",
                  "value": "IndivdualName"
                },
                {
                  "key": "deploy.qa",
                  "value": "2018-10-20"
                },
                {
                  "key": "deploy.dev",
                  "value": "2018-11-19"
                }
              ],
              "virtual_repos": [
                "libs-production "
              ]
            }
          ],
          "range": {
            "start_pos": 0,
            "end_pos": 479,
            "total": 479
          }
        },
        "output": [
          {
            "key": "deploy.prod.TLE",
            "value": "2018-10-20"
          },
          {
            "key": "deploy.prodXYZ",
            "value": "2018-10-20"
          },
          {
            "key": "deploy.prodPDQ",
            "value": "2018-10-20"
          },
          {
            "key": "deploy.prod.ABC",
            "value": "2018-10-21"
          },
          {
            "key": "deploy.prodPDQ",
            "value": "2018-10-22"
          },
          {
            "key": "deploy.prodABC",
            "value": "2018-10-20"
          }
        ]
      }
    ],
    "identifier": 55896711
  },
  {
    "context": [
      "Want to convert a json into CSV file. CSV file require all the Line Item Object 1 per line + that line should also contain PURCHASEORDERNO.",
      "You have to store the `PURCHASEORDERNO` in a variable in order to add it to each row.",
      "jq -r '.RECEIPT.HEADER[] | .PURCHASEORDERNO as $pono | .LINE[] | [ $pono, .ITEMCODE, .QUANTITY ] | @csv' input"
    ],
    "utterance": "Produce one CSV line for each LINE item, including its PURCHASEORDERNO, ITEMCODE, and QUANTITY.",
    "expressions": [
      ".RECEIPT.HEADER[] | .PURCHASEORDERNO as $pono | .LINE[] | [ $pono, .ITEMCODE, .QUANTITY ] | @csv"
    ],
    "data": [
      {
        "input": {
          "RECEIPT": {
            "HEADER": [
              {
                "LINE": [
                  {
                    "ITEMCODE": "CF7219",
                    "QUANTITY": "6"
                  },
                  {
                    "ITEMCODE": "CF7223",
                    "QUANTITY": "8"
                  }
                ],
                "SUPPCUSTNAME": "CONFOIL CONTAINERS",
                "SUPPCUSTCODE": "CON001",
                "PROCESSDATE": "20190321",
                "PURCHASEORDERNO": "P62541"
              },
              {
                "LINE": [
                  {
                    "ITEMCODE": "CF7219",
                    "QUANTITY": "6"
                  },
                  {
                    "ITEMCODE": "CF7223",
                    "QUANTITY": "8"
                  }
                ],
                "SUPPCUSTNAME": "CONFOIL CONTAINERS",
                "SUPPCUSTCODE": "CON001",
                "PROCESSDATE": "20190321",
                "PURCHASEORDERNO": "P62542"
              }
            ]
          }
        },
        "output": [
          "\"P62541\",\"CF7219\",\"6\"",
          "\"P62541\",\"CF7223\",\"8\"",
          "\"P62542\",\"CF7219\",\"6\"",
          "\"P62542\",\"CF7223\",\"8\""
        ]
      }
    ],
    "identifier": 55946071
  },
  {
    "context": [
      "How to produce the Cartesian square of an array in `jq`?",
      "Input:\n[0,1,2]",
      "Output:\n[[0,0],[0,1],[0,2],\n [1,0],[1,1],[1,2],\n [2,0],[2,1],[2,2]]",
      "One way to generate the array of pairs in the specified order would be as follow:",
      "data | [.[] as $i | .[] as $j | [$i, $j] ] "
    ],
    "utterance": "Produce all ordered pairs of elements from the array [0,1,2].",
    "expressions": [
      ".[] as $i | .[] as $j | [$i, $j]",
      "[.[] as $i | .[] as $j | [$i, $j] ]"
    ],
    "data": [
      {
        "input": [
          0,
          1,
          2
        ],
        "output": [
          [
            0,
            0
          ],
          [
            0,
            1
          ],
          [
            0,
            2
          ],
          [
            1,
            0
          ],
          [
            1,
            1
          ],
          [
            1,
            2
          ],
          [
            2,
            0
          ],
          [
            2,
            1
          ],
          [
            2,
            2
          ]
        ]
      }
    ],
    "identifier": 55954949
  },
  {
    "context": [
      "Can I use jq to format the object into a [Prometheus](https://prometheus.io/)-compatible format so I can just use the output to push the data to a Prometheus Pushgateway?",
      "The required result would look like\n\n    foo 42\n    bar{label1=\"value1\"} 12.34\n    baz -12\n\ni.e. space-separated with newlines (no `\\r`) and without quotes except for the label value.",
      "Use `keys_unsorted` to get object keys ... generate desired output by means of string interpolation.",
      "`jq -r 'keys_unsorted[] as $k | \"\\($k) \\(.[$k])\"' file`",
      "On a Windows platform ... use the -j command-line option and manually insert the desired 'newline' characters like so:\n\n    jq -rj 'to_entries[] | \"\\(.key) \\(.value)\\n\"' file"
    ],
    "utterance": "Format each key-value pair from the object as 'key value' on its own line, with no extra quotes or carriage returns, matching Prometheus metrics format.",
    "expressions": [
      "keys_unsorted[] as $k | \"\\($k) \\(.[$k])\"",
      "to_entries[] | \"\\(.key) \\(.value)\""
    ],
    "data": [
      {
        "input": {
          "foo": 42,
          "baz": -12,
          "bar{label1=\"value1\"}": 12.34
        },
        "output": "foo 42\nbaz -12\nbar{label1=\"value1\"} 12.34\n"
      }
    ],
    "identifier": 55959877
  },
  {
    "context": [
      "The following example from the [jq docs](https://stedolan.github.io/jq/manual/v1.5/#in) worked as expected -- \r\n```sh\r\n$ echo '[1,2]' | jq 'map(in([0,1]))'\r\n[\r\n  true,\r\n  false\r\n]\r\n```",
      "but making the values into strings failed -\r\n```sh\r\n$ echo '[\"1\", \"2\"]' | jq 'map(in([\"0\",\"1\"]))'\r\njq: error (at <stdin>:1): Cannot check whether array has a string key\r\n```",
      "If you wanted to test membership in the array, there isn't a builtin but you could craft it yourself. Though `contains/1` is close but not quite since it tests if strings are substrings and not equal. `any/2` could be used to do this.\r\n\r\n    def has_value($value):\r\n        any(.[]; . == $value);\r\n\r\n    def in_array($arr): # swapped input version\r\n        . as $value | any($arr[]; . == $value);",
      "`index/1` is the builtin that can most conveniently be used for checking array membership.  Although it is not strictly boolean, the semantics of `if` and `//` make it convenient to use as though it were.  If you want a strictly boolean test, then simply use the idiom `index(_) != null`.",
      "actually [inside][1] does seem to do the trick (apparently added in v1.5)\r\n\r\n    jq -n '[123,444,565,344,\"333\",111,1111,87] | map([.]|inside([111,333,344]))'\r\n\r\nproduces \r\n\r\n    [\r\n      false,\r\n      false,\r\n      false,\r\n      true,\r\n      false,\r\n      true,\r\n      false,\r\n      false\r\n    ]"
    ],
    "utterance": "For each element in an array, determine if it is present in a given array of values, returning an array of booleans.",
    "expressions": [
      "map([.]|inside([111,333,344]))",
      "map(. as $v | [ $v ] | inside([111,333,344]))",
      "map(index(111) != null or index(333) != null or index(344) != null)",
      "map(any([111,333,344][]; . == .))"
    ],
    "data": [
      {
        "input": [
          123,
          444,
          565,
          344,
          "333",
          111,
          1111,
          87
        ],
        "output": [
          false,
          false,
          false,
          true,
          false,
          true,
          false,
          false
        ]
      }
    ],
    "identifier": 55932654
  },
  {
    "context": [
      "Specifically, I want to list all of the AWS security groups that have port 22 rules in them.",
      "I want to see this:",
      "GroupName: \"https\"",
      "GroupID: \"sg-22222222\"",
      "Don\u2019t descend into children if you need parent.",
      ".SecurityGroups[]\n| select(any(.IpPermissions[]; .FromPort == 22))\n| .GroupName, .GroupId\nshould work."
    ],
    "utterance": "List all security groups where any rule has FromPort equal to 22, showing their GroupName and GroupId.",
    "expressions": [
      ".SecurityGroups[] | select(any(.IpPermissions[]; .FromPort == 22)) | .GroupName, .GroupId"
    ],
    "data": [
      {
        "input": {
          "SecurityGroups": [
            {
              "Description": "ssh and web group",
              "IpPermissions": [
                {
                  "FromPort": 22,
                  "ToPort": 22
                },
                {
                  "FromPort": 80,
                  "ToPort": 80
                }
              ],
              "GroupName": "ssh-web",
              "GroupId": "sg-11111111"
            },
            {
              "Description": "https group",
              "IpPermissions": [
                {
                  "FromPort": 443,
                  "ToPort": 443
                },
                {
                  "FromPort": 8443,
                  "ToPort": 8443
                }
              ],
              "GroupName": "https",
              "GroupId": "sg-22222222"
            }
          ]
        },
        "output": [
          "ssh-web",
          "sg-11111111"
        ]
      }
    ],
    "identifier": 55964317
  },
  {
    "context": [
      "I would like to stream all the key-value pairs inside of `.stats.daily` and `.stats.monthly` separately.",
      "using jq 1.6, we see that:\r\n\r\n    atomize(2|truncate_stream(\r\n      inputs | select( .[0][0:2] == [\"stats\",\"daily\"] ) ))\r\n\r\nwould produce:\r\n\r\n    {\"k1\":{\"a\":[1]}}\r\n    {\"k2\":{\"a\":[1]}}\r\n    {\"kN\":{\"a\":[1]}}\r\n"
    ],
    "utterance": "Stream each key-value pair from the daily object under stats as separate objects.",
    "expressions": [
      "atomize(2|truncate_stream(inputs | select(.[0][0:2] == [\"stats\",\"daily\"])))"
    ],
    "data": [
      {
        "input": {
          "users": {},
          "stats": {
            "daily": {
              "k1": {
                "a": [
                  1
                ]
              },
              "k2": {
                "a": [
                  1
                ]
              },
              "kN": {
                "a": [
                  1
                ]
              }
            },
            "monthly": {
              "p1": {
                "b": [
                  2
                ]
              },
              "p2": {
                "b": [
                  2
                ]
              },
              "pN": {
                "b": [
                  2
                ]
              }
            }
          }
        },
        "output": [
          {
            "k1": {
              "a": [
                1
              ]
            }
          },
          {
            "k2": {
              "a": [
                1
              ]
            }
          },
          {
            "kN": {
              "a": [
                1
              ]
            }
          }
        ]
      }
    ],
    "identifier": 55922362
  },
  {
    "context": [
      "In the below Json file, I am trying to extract \"Name\": \"abcd\",\"Version\": \"1.0.2\" and \"Severity\": \"Medium\".",
      "So far I am able to extract the values of Name & version using the jq command below.",
      "jq -r '.data.Layer| .Features[] | \"\\(.Name) \\(.Version)\"' status.json",
      "but when I try to extract values of \"Severity\" field using the below command \n\n    `jq -r '.data.Layer| .Features[] | \"\\(.Name) \\(.Version)\"| .Vulnerabilities[].Severity' status.json`\n I get the error message in the title.",
      "jq -r '.data.Layer| .Features[] | .Name ,.Version, .Vulnerabilities[].Severity' input",
      "jq -r '.data.Layer| .Features[] | \"\\(.Name)  \\(.Version)  \\(.Vulnerabilities[].Severity)\"' input",
      "If you use `Vulnerabilities[]?` instead of `[]` jq will just skip the Features which don't have a Vulnerability."
    ],
    "utterance": "Extract the name, version, and severity for each feature, including only features where vulnerabilities are present.",
    "expressions": [
      ".data.Layer.Features[] | \"\u000b(.Name) \u000b(.Version) \u000b(.Vulnerabilities[]?.Severity)\"",
      ".data.Layer.Features[] | select(.Vulnerabilities) | .Name, .Version, (.Vulnerabilities[] | .Severity)"
    ],
    "data": [
      {
        "input": {
          "status": "scanned",
          "data": {
            "Layer": {
              "IndexedByVersion": 3,
              "NamespaceName": "debian:9",
              "ParentName": "e762",
              "Name": ".4530bfac-5e99-4138-b071-4286c06669a3",
              "Features": [
                {
                  "Name": "openssl1.0",
                  "VersionFormat": "dpkg",
                  "NamespaceName": "debian:9",
                  "AddedBy": "85aa73fb8281cc252ed7e151f10386f36588ec6c967d45136103a4e1e705a81c.01bc7eff-9a5d-43f5-ab14-2e3e470cba77",
                  "Version": "1.0.2q-1~deb9u1",
                  "Vulnerabilities": [
                    {
                      "Severity": "Medium",
                      "NamespaceName": "debian:9",
                      "Link": "xxxx",
                      "FixedBy": "1.0.2r-1~deb9u1",
                      "Description": " n must call SSL_shutdown() twice even if a protocol error has occurred (applications should not do this but some do anyway). Fixed in OpenSSL 1.0.2r (Affected 1.0.2-1.0.2q).",
                      "Name": "CVE-2019-1559",
                      "Metadata": {
                        "NVD": {
                          "CVSSv2": {
                            "Score": 4.3,
                            "Vectors": "AV:N/AC:M/Au:N/C:P/I:N"
                          }
                        }
                      }
                    }
                  ]
                },
                {
                  "VersionFormat": "dpkg",
                  "NamespaceName": "debian:9",
                  "Version": "0.16-1+deb9u1",
                  "Name": "libidn2-0",
                  "AddedBy": "85aa73fb8281cc252ed7e151f10386f36588ec6c967d45136103a4e1e705a81c.01bc7eff-9a5d-43f5-ab14-2e3e470cba77"
                }
              ]
            }
          }
        },
        "output": [
          "openssl1.0 1.0.2q-1~deb9u1 Medium"
        ]
      }
    ],
    "identifier": 55841335
  },
  {
    "context": [
      "When I try to use map_values, so I can also get the property names, as in:\r\n```\r\njq 'map_values(select(contains(\"PATTERN\")==true))' largefile.json > res.json\r\n```\r\n\r\nthe query takes forever.",
      "Is there an equivalent query that is fast like map, and which can also provide me with the key:value pairs?",
      "Just use `with_entries/1` it allows you to effectively filter out properties of an object based on the key and/or value.",
      "`with_entries(select(.value | contains(\"PATTERN\")))`"
    ],
    "utterance": "Return all key-value pairs where the value contains a specific string pattern.",
    "expressions": [
      "with_entries(select(.value | contains(\"PATTERN\")))"
    ],
    "data": [
      {
        "input": {
          "prop1": "large string",
          "prop2": "another large string",
          "prop3": "yet another large string"
        },
        "output": {
          "prop2": "another large string",
          "prop3": "yet another large string"
        }
      }
    ],
    "identifier": 55973419
  },
  {
    "context": [
      "I need to extract value from \"client_score_avg\" key.",
      "I think you just need to do below.",
      "jq '.data[].wifi_score.client_score_avg' file.json"
    ],
    "utterance": "Extract the value of client_score_avg from the wifi_score object inside each item of the data array.",
    "expressions": [
      ".data[].wifi_score.client_score_avg",
      ".data[0].wifi_score.client_score_avg"
    ],
    "data": [
      {
        "input": {
          "meta": {
            "rc": "ok"
          },
          "data": [
            {
              "average_wifi_utilization": {
                "total": 21.928571428571427,
                "na": 9.035714285714286,
                "ng": 34.82142857142857
              },
              "devices_status": {
                "uap": {
                  "adopted": 28,
                  "connected": 28,
                  "disconnected": 0,
                  "pending": 0,
                  "disabled": 0
                },
                "usw": {
                  "adopted": 2,
                  "connected": 2,
                  "disconnected": 0,
                  "pending": 0
                },
                "ugw": {
                  "adopted": 0,
                  "connected": 0,
                  "disconnected": 0,
                  "pending": 0
                }
              },
              "wifi_score": {
                "client_score_avg": 81,
                "clients_with_poor_score": 8,
                "clients_with_fair_score": 3,
                "clients": 99,
                "retry_rate": 0,
                "signal": -61,
                "latency": 0
              }
            }
          ]
        },
        "output": 81
      }
    ],
    "identifier": 55969065
  },
  {
    "context": [
      "I would like to get the paths of \"name\" needed to get to each \"name\" values.",
      "Considering the above code, I would like the following result:",
      "\"alpha\"\n\"beta.beta_sub_1\"\n\"beta.beta_sub_2\"\n\"beta\"\n\"gamma.gamma_sub_1.gamma_sub_sub_1\"\n\"gamma.gamma_sub_1\"\n\"gamma\"",
      "the following jq program produces the required output:",
      "def descend:\n  select( type == \"object\" and has(\"name\") )\n  | if has(\"fields\") then ([.name] + (.fields[] | descend)) else empty end, \n    [.name] ;\n\n.[ ]\n| descend\n| join(\".\")"
    ],
    "utterance": "Get all dot-separated paths representing the sequence of \"name\" values from the root to every object with a \"name\" field, including intermediate and leaf nodes, following all nested \"fields\" arrays.",
    "expressions": [
      "def descend:\n  select(type == \"object\" and has(\"name\"))\n  | if has(\"fields\") then ([.name] + (.fields[] | descend)) else empty end,\n    [.name];\n\n.[] | descend | join(\".\")"
    ],
    "data": [
      {
        "input": [
          {
            "name": "alpha"
          },
          {
            "fields": [
              {
                "name": "beta_sub_1"
              },
              {
                "name": "beta_sub_2"
              }
            ],
            "name": "beta"
          },
          {
            "fields": [
              {
                "fields": [
                  {
                    "name": "gamma_sub_sub_1"
                  }
                ],
                "name": "gamma_sub_1"
              }
            ],
            "name": "gamma"
          }
        ],
        "output": [
          "alpha",
          "beta.beta_sub_1",
          "beta.beta_sub_2",
          "beta",
          "gamma.gamma_sub_1.gamma_sub_sub_1",
          "gamma.gamma_sub_1",
          "gamma"
        ]
      }
    ],
    "identifier": 55970566
  },
  {
    "context": [
      "I wanted all non null values of \"A\" which can be repeated anywhere in json. I wanted output like all contents of \"A\"",
      "jq -c '..|objects|.A//empty' <<< \"$json_value\"",
      "{\n  \"A\": {\"id\":4},\n  \"B\": {\"foo\":0},\n  \"C\": {\"A\": {\"id\":2}},\n  \"E\": {\"A\":null},\n  \"F\": {\"foo\":0}\n}",
      "{\n  \"id\":4\n}\n{\n  \"id\":2\n}"
    ],
    "utterance": "Print all non-null values of key \"A\" occurring at any depth in the data.",
    "expressions": [
      "..|objects|.A//empty"
    ],
    "data": [
      {
        "input": {
          "A": {
            "id": 4
          },
          "B": {
            "foo": 0
          },
          "C": {
            "A": {
              "id": 2
            }
          },
          "E": {
            "A": null
          },
          "F": {
            "foo": 0
          }
        },
        "output": [
          {
            "id": 4
          },
          {
            "id": 2
          }
        ]
      }
    ],
    "identifier": 55989933
  },
  {
    "context": [
      "But what I really need is a boolean that will return `true` if there is more than one object in the queue with that value for `downloadId`.",
      "Here is a blob:\r\n\r\n    [\r\n      {\r\n        ...\r\n        \"downloadId\": \"1C2DE46A5B4258BE7AC47FEFAE71432897417126\",\r\n        ...\r\n      },\r\n      {\r\n        ...\r\n        \"downloadId\": \"728084A13FD172FED437C6AE503A8CF4A8D317AE\",\r\n        ...\r\n      },\r\n      {\r\n        ...\r\n        \"downloadId\": \"ABCA01479FCAB77D0A8A5C499D5ABAA147E97B47\",\r\n        ...\r\n      }\r\n    ]",
      "To achieve an efficient solution, let us define `repeated/2` to check whether a given value occurs more than once in a stream:",
      "With the above, the solution would be:\r\n\r\n    repeated(.[] | .downloadId; \"ABCA01479FCAB77D0A8A5C499D5ABAA147E97B47\")"
    ],
    "utterance": "Return true if more than one object in the input has downloadId equal to \"ABCA01479FCAB77D0A8A5C499D5ABAA147E97B47\".",
    "expressions": [
      "def repeated(stream; $value):\n  label $done\n  | foreach stream as $x (0;\n       if $x == $value then  . + 1 else . end;\n       if . == 2 then true, break $done else empty end)\n  // false;\n\nrepeated(.[] | .downloadId; \"ABCA01479FCAB77D0A8A5C499D5ABAA147E97B47\")"
    ],
    "data": [
      {
        "input": [
          {
            "sizeleft": 805679928.0,
            "timeleft": "00:00:00",
            "estimatedCompletionTime": "2019-05-03T17:30:31.370856Z",
            "status": "Paused",
            "trackedDownloadStatus": "Ok",
            "statusMessages": [],
            "downloadId": "1C2DE46A5B4258BE7AC47FEFAE71432897417126",
            "id": 1065601863
          },
          {
            "sizeleft": 836459293.0,
            "timeleft": "00:00:00",
            "estimatedCompletionTime": "2019-05-03T17:30:31.370864Z",
            "status": "Paused",
            "trackedDownloadStatus": "Ok",
            "statusMessages": [],
            "downloadId": "728084A13FD172FED437C6AE503A8CF4A8D317AE",
            "id": 1177597916
          },
          {
            "sizeleft": 836459293.0,
            "timeleft": "00:00:00",
            "estimatedCompletionTime": "2019-05-03T17:30:31.370864Z",
            "status": "Paused",
            "trackedDownloadStatus": "Ok",
            "statusMessages": [],
            "downloadId": "ABCA01479FCAB77D0A8A5C499D5ABAA147E97B47",
            "id": 1177597916
          }
        ]
      }
    ],
    "identifier": 55974870
  },
  {
    "context": [
      "output expecting to get :\n```\n\"ResourceARN\",\"Name\",\"AppCluster\",\"AppEnv\",\"AppGroup\",\"App01\",\"aws:autoscaling:groupName\",\"aws:ec2launchtemplate:id\",\"aws:ec2launchtemplate:version\"\n\"arn:aws:ec2:us-east-1:027906322765228:customer-gateway/cgw-e404f4440d\",\"useast-prod-vpn01-cisco\",null,null,null,null,null,null,null\n\"arn:aws:ec2:us-east-1:017906322765228:customer-gateway/cgw-e7a447508555e\",\"useast-prod-vpn02-cisco\",null,null,null,null,null,null,null\n\"arn:aws:ec2:us-east-1:5079063766562328:customer-gateway/cgw-e7a44754408e\",null,null,null,null,null,null,null,null\n\"arn:aws:ec2:us-east-1:07945406375465228:image/ami-012446b78ea15546fbd\",\"processor-USE-img-18022019\",null,null,null,null,null,null,null\n\"arn:aws:ec2:us-east-1:079063765434343228:image/ami-0624f58fdf53eacd3775\",null,\"DevOpsUSE1\",\"Image\",\"Image\",null,null,null,null\n\"arn:aws:ec2:us-east-1:079550666376445228:instance/i-0087f44110c478d49\",null,null,\"Production\",null,\"Inst01USE1\",\"usev-app01-ond-asg01\",\"lt-0ec354ad560e508cc\",\"8\"\n```",
      "$ jq -r '\nreduce .ResourceTagMappingList[] as $p\n( { names: null, rows: null };\n  ( $p | { ResourceARN } + ( .Tags // [] | from_entries ) ) as $p\n  | .names[$p | keys_unsorted[]] = 0\n  | .rows += [$p]\n) | ( .names | keys_unsorted ) as $names\n| $names, ( .rows[] | [.[$names[]]] )\n| @csv' file"
    ],
    "utterance": "Convert the list of resource mappings to a CSV table with columns for ResourceARN and all tag keys as headers, filling missing fields with null.",
    "expressions": [
      "reduce .ResourceTagMappingList[] as $p\n( { names: null, rows: null };\n  ( $p | { ResourceARN } + ( .Tags // [] | from_entries ) ) as $p\n  | .names[$p | keys_unsorted[]] = 0\n  | .rows += [$p]\n) | ( .names | keys_unsorted ) as $names\n| $names, ( .rows[] | [.[$names[]]] )\n| @csv"
    ],
    "data": [
      {
        "input": {
          "ResourceTagMappingList": [
            {
              "ResourceARN": "arn:aws:ec2:us-east-1:027906322765228:customer-gateway/cgw-e404f4440d",
              "Tags": [
                {
                  "Value": "useast-prod-vpn01-cisco",
                  "Key": "Name"
                }
              ]
            },
            {
              "ResourceARN": "arn:aws:ec2:us-east-1:017906322765228:customer-gateway/cgw-e7a447508555e",
              "Tags": [
                {
                  "Value": "useast-prod-vpn02-cisco",
                  "Key": "Name"
                }
              ]
            },
            {
              "ResourceARN": "arn:aws:ec2:us-east-1:5079063766562328:customer-gateway/cgw-e7a44754408e"
            },
            {
              "ResourceARN": "arn:aws:ec2:us-east-1:07945406375465228:image/ami-012446b78ea15546fbd",
              "Tags": [
                {
                  "Value": "processor-USE-img-18022019",
                  "Key": "Name"
                }
              ]
            },
            {
              "ResourceARN": "arn:aws:ec2:us-east-1:079063765434343228:image/ami-0624f58fdf53eacd3775",
              "Tags": [
                {
                  "Value": "DevOpsUSE1",
                  "Key": "AppCluster"
                },
                {
                  "Value": "Image",
                  "Key": "AppEnv"
                },
                {
                  "Value": "Image",
                  "Key": "AppGroup"
                }
              ]
            },
            {
              "ResourceARN": "arn:aws:ec2:us-east-1:079063765228:instance/i-0087f44110c478d49",
              "Tags": [
                {
                  "Value": "Inst01USE1",
                  "Key": "App01"
                },
                {
                  "Value": "Production",
                  "Key": "AppEnv"
                },
                {
                  "Value": "usev-app01-ond-asg01",
                  "Key": "aws:autoscaling:groupName"
                },
                {
                  "Value": "lt-0ec354ad560e508cc",
                  "Key": "aws:ec2launchtemplate:id"
                },
                {
                  "Value": "8",
                  "Key": "aws:ec2launchtemplate:version"
                }
              ]
            }
          ]
        },
        "output": "\"ResourceARN\",\"Name\",\"AppCluster\",\"AppEnv\",\"AppGroup\",\"App01\",\"aws:autoscaling:groupName\",\"aws:ec2launchtemplate:id\",\"aws:ec2launchtemplate:version\"\n\"arn:aws:ec2:us-east-1:027906322765228:customer-gateway/cgw-e404f4440d\",\"useast-prod-vpn01-cisco\",null,null,null,null,null,null,null\n\"arn:aws:ec2:us-east-1:017906322765228:customer-gateway/cgw-e7a447508555e\",\"useast-prod-vpn02-cisco\",null,null,null,null,null,null,null\n\"arn:aws:ec2:us-east-1:5079063766562328:customer-gateway/cgw-e7a44754408e\",null,null,null,null,null,null,null,null\n\"arn:aws:ec2:us-east-1:07945406375465228:image/ami-012446b78ea15546fbd\",\"processor-USE-img-18022019\",null,null,null,null,null,null,null\n\"arn:aws:ec2:us-east-1:079063765434343228:image/ami-0624f58fdf53eacd3775\",null,\"DevOpsUSE1\",\"Image\",\"Image\",null,null,null,null\n\"arn:aws:ec2:us-east-1:079063765228:instance/i-0087f44110c478d49\",null,null,\"Production\",null,\"Inst01USE1\",\"usev-app01-ond-asg01\",\"lt-0ec354ad560e508cc\",\"8\"\n"
      }
    ],
    "identifier": 55775930
  }
]