[
  {
    "identifier": 71406984
  },
  {
    "context": [
      "Using a jq, is there an easy way to get a valid snippet of the json that only contains the first few entries from the ```data``` list?",
      "For example is there a query that would look at the whole json file and return to me a valid json that only contains the first 4 entries from ```data```?",
      "Based on your snippet, the relevant jq would be:\r\n\r\n    .data |= .[:4]"
    ],
    "utterance": "Return the original object, but with the 'data' array containing only its first 4 elements.",
    "expressions": [
      ".data |= .[:4]"
    ],
    "data": [
      {
        "input": {
          "info": {
            "name": "some-name"
          },
          "data": [
            {
              "a": 1
            },
            {
              "b": 2
            },
            {
              "c": 3
            },
            {
              "d": 4
            },
            {
              "e": 5
            },
            {
              "f": 6
            },
            {
              "g": 7
            }
          ]
        },
        "output": {
          "info": {
            "name": "some-name"
          },
          "data": [
            {
              "a": 1
            },
            {
              "b": 2
            },
            {
              "c": 3
            },
            {
              "d": 4
            }
          ]
        }
      }
    ],
    "identifier": 71387033
  },
  {
    "context": [
      "I am trying to use jq to filter for instances where the key \"name\" contains \"dev\" but does not contain \"master\" and output the value of \"name\".",
      ".results[] | select(.name | contains(\"dev\") and (contains(\"master\") | not)) | .name",
      ".results[] | select([.name | contains(\"dev\", \"master\")] == [true, false]) | .name"
    ],
    "utterance": "Output the values of \"name\" for objects where the \"name\" contains \"dev\" but does not contain \"master\".",
    "expressions": [
      ".results[] | select(.name | contains(\"dev\") and (contains(\"master\") | not)) | .name",
      ".results[] | select([.name | contains(\"dev\", \"master\")] == [true, false]) | .name"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "name": "package-dev_0.0.1-dev.er56ut.pkg"
            },
            {
              "name": "package-dev_0.0.23-master.qwk89mo.pkg"
            },
            {
              "name": "package_0.9.1-dev.til39aw.pkg"
            },
            {
              "name": "package_0.3.3-master.mbw80lk.pkg"
            }
          ]
        },
        "output": [
          "package-dev_0.0.1-dev.er56ut.pkg",
          "package_0.9.1-dev.til39aw.pkg"
        ]
      }
    ],
    "identifier": 71391823
  },
  {
    "context": [
      "$ jq '.components.1[0].x' file.json",
      "jq: error: syntax error, unexpected LITERAL, expecting $end (Unix shell quoting issues?) at <top-level>, line 1:",
      "You can use brackets:",
      "$ jq '.components[\"1\"][0].x' file.json",
      "jq '.components[\"1\"]'",
      "jq '.components.\"1\"'",
      "jq '.components[\"1\"][1]'",
      "jq '.components.\"1\"[1]'",
      "Therefore, this should be what you are trying to do:",
      "jq '.components.\"1\"[ ].x'"
    ],
    "utterance": "Access the value of the key x in the first element of the array under the key \"1\" in the components object, where the key \"1\" is a string.",
    "expressions": [
      ".components[\"1\"][0].x",
      ".components.\"1\"[0].x"
    ],
    "data": [
      {
        "input": {
          "components": {
            "1": [
              {
                "x": 14,
                "y": 15
              },
              {
                "A": 5,
                "B": 6
              }
            ]
          }
        },
        "output": 14
      }
    ],
    "identifier": 71399346
  },
  {
    "context": [
      "I would like to select, and list the crds which are containing the \"v1beta1\" in the \n\n> .spec.versions.*.name",
      ".spec.versions[] | select(.name | contains(\"v1beta1\"))",
      "This will show the name using jsonpath: `kubectl get crd -o jsonpath='{range .items[?(@.spec.versions[].name==\"v1beta1\")].metadata}{.name}{\"\\n\"}'`"
    ],
    "utterance": "List the names of CRDs whose spec.versions array has at least one entry with name equal to 'v1beta1'.",
    "expressions": [
      ".items[] | select(any(.spec.versions[]; .name == \"v1beta1\")) | .metadata.name"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "metadata": {
                "name": "foo.example.com"
              },
              "spec": {
                "versions": [
                  {
                    "name": "v1alpha1"
                  },
                  {
                    "name": "v1beta1"
                  }
                ]
              }
            },
            {
              "metadata": {
                "name": "bar.example.com"
              },
              "spec": {
                "versions": [
                  {
                    "name": "v1"
                  }
                ]
              }
            }
          ]
        },
        "output": [
          "foo.example.com"
        ]
      }
    ],
    "identifier": 71398800
  },
  {
    "context": [
      "The requirement is to replace values of keys existing in both files by values from second file. And add keys doesn't exist in first should be appended to the output JSON.",
      "`jq` provides \u201cobject multiplication\u201d feature:",
      "jq '. * input' file1.json file2.json"
    ],
    "utterance": "Merge two objects where keys from the second overwrite those in the first, and new keys in the second are added to the result.",
    "expressions": [
      ". * input"
    ],
    "data": [
      {
        "input": [
          {
            "foo": "bar",
            "aaa": "aaa",
            "count": 0
          },
          {
            "bbb": "bbb",
            "count": 1
          }
        ],
        "output": {
          "foo": "bar",
          "aaa": "aaa",
          "count": 1,
          "bbb": "bbb"
        }
      }
    ],
    "identifier": 71411942
  },
  {
    "context": [
      "test2=$(/bin/lshw -quiet -json -C network|/bin/jq '.[$i] | .logicalname')",
      "No, don't inject shell variables into your jq filter! Rather use options provided by jq to introduce them as variables inside jq. In your case, when using a variable that holds a number, --argjson will do:",
      "i=1",
      "test2=$(/bin/lshw -quiet -json -C network|/bin/jq --argjson i $i '.[$i] | .logicalname')"
    ],
    "utterance": "Select the 'logicalname' field from the object at index 1, where the index is provided by a shell variable.",
    "expressions": [
      ".[$i] | .logicalname"
    ],
    "data": [
      {
        "input": [
          {
            "logicalname": "eno1"
          },
          {
            "logicalname": "wlp9s0"
          }
        ],
        "output": "wlp9s0"
      }
    ],
    "identifier": 71394745
  },
  {
    "context": [
      "How do I express what I want to express, which is if there is no matching Tag, the \"hash\" property of the output object should be set to null?",
      "Don&#39;t let it produce `empty`. One way would be to give the `select` filter an alternative: `select(.Key==\"hash\") // null`",
      "jq '{\"name\": .Name, \"hash\": (.Tags[] | select(.Key==\"hash\") // null | .Value)}'",
      "{\n  \"name\": \"NAME\",\n  \"hash\": null\n}"
    ],
    "utterance": "Return an object with the name and the value of the tag whose Key equals \"hash\"; if not present, set hash to null.",
    "expressions": [
      "{ \"name\": .Name, \"hash\": (.Tags[] | select(.Key==\"hash\") // null | .Value) }"
    ],
    "data": [
      {
        "input": {
          "Name": "NAME",
          "Tags": [
            {
              "Key": "KEY",
              "Value": "HASH"
            }
          ]
        },
        "output": {
          "name": "NAME",
          "hash": null
        }
      },
      {
        "input": {
          "Name": "NAME",
          "Tags": [
            {
              "Key": "hash",
              "Value": "HASH"
            }
          ]
        },
        "output": {
          "name": "NAME",
          "hash": "HASH"
        }
      }
    ],
    "identifier": 71403976
  },
  {
    "context": [
      "query=$(echo \".[] | select((.resource_type==\\\"Topic\\\") and (.resource_name | startswith(\\\"${myvar}\\\") | not))\")",
      "echo ${data} | jq ${query}",
      "query='.[] | select((.resource_type==$type) and (.resource_name | startswith($var) | not))'",
      "echo \"${data}\" | jq --arg type \"Topic\" --arg var \"${myvar}\" \"${query}\""
    ],
    "utterance": "Filter the array to include only objects where resource_type is Topic and resource_name does not start with data1.",
    "expressions": [
      ".[] | select((.resource_type==$type) and (.resource_name | startswith($var) | not))"
    ],
    "data": [
      {
        "input": [
          {
            "resource_name": "data1.something",
            "resource_type": "Topic"
          },
          {
            "resource_name": "data2.something",
            "resource_type": "Topic"
          }
        ],
        "output": {
          "resource_name": "data2.something",
          "resource_type": "Topic"
        }
      }
    ],
    "identifier": 71431490
  },
  {
    "context": [
      "The idea is that I have an object that is part of an array that itself is the value of a parent key. I want to use the value of that key to alter the values in the original child object.",
      "echo '{\"red\": [{\"fruit\": \"apple\", \"grows_on\":\"tree\"}, {\"fruit\":\"raspberry\",\"grows_on\":\"vine\"}], \"green\": [{\"fruit\": \"apple\", \"grows_on\":\"tree\"}, {\"fruit\":\"gooseberry\",\"grows_on\":\"bush\"}]}' | \njq '...'",
      "You could use `with_entries` (which itself is a shortcut to `to_entries | map(\u2026) | from_entries`) to deconstruct each field into a key-value pair, manipulate to your liking with access to key and value, and reconstruct it again.",
      "The inner filter saves the key into a variable, descends into each value's `fruit` and updates `|=` its name, according to the key and its cuurent name `.`.",
      "jq 'with_entries(.key as $key | .value[].fruit |= $key + \"_\" + .)'"
    ],
    "utterance": "Prepend each fruit name with the name of its parent key in all top-level object fields containing arrays of objects with a 'fruit' field.",
    "expressions": [
      "with_entries(.key as $key | .value[].fruit |= $key + \"_\" + .)",
      "objects |= with_entries(.key as $key | if IN(\"red\", \"green\"; $key) then (.value[] | objects.fruit // empty) |= $key + \"_\" + . else . end)"
    ],
    "data": [
      {
        "input": {
          "red": [
            {
              "fruit": "apple",
              "grows_on": "tree"
            },
            {
              "fruit": "raspberry",
              "grows_on": "vine"
            }
          ],
          "green": [
            {
              "fruit": "apple",
              "grows_on": "tree"
            },
            {
              "fruit": "gooseberry",
              "grows_on": "bush"
            }
          ]
        },
        "output": {
          "red": [
            {
              "fruit": "red_apple",
              "grows_on": "tree"
            },
            {
              "fruit": "red_raspberry",
              "grows_on": "vine"
            }
          ],
          "green": [
            {
              "fruit": "green_apple",
              "grows_on": "tree"
            },
            {
              "fruit": "green_gooseberry",
              "grows_on": "bush"
            }
          ]
        }
      }
    ],
    "identifier": 71418708
  },
  {
    "context": [
      "How to get my full json without the attribute `timeouts` for only one type of resources `google_dns_record_set`.",
      "Pull the `del` command up front to include the whole selection as its own filter",
      "del(.resources[] | select(.type==\"google_dns_record_set\").instances[].attributes.timeouts)"
    ],
    "utterance": "Remove the attribute timeouts from all attributes objects belonging to resources of type google_dns_record_set, returning the full data structure otherwise unchanged.",
    "expressions": [
      "del(.resources[] | select(.type==\"google_dns_record_set\").instances[].attributes.timeouts)"
    ],
    "data": [
      {
        "input": {
          "version": 4,
          "terraform_version": "1.0.6",
          "serial": 635,
          "lineage": "6a9c2392-fdae-2b54-adcc-7366f262ffa4",
          "outputs": {
            "test": "test1"
          },
          "resources": [
            {
              "module": "module.resources",
              "mode": "data",
              "type": "google_client_config"
            },
            {
              "module": "module.xxx.module.module1[\"cluster\"]",
              "mode": "managed",
              "type": "google_dns_record_set",
              "name": "public_ip_ic_dns",
              "provider": "module.xxx.provider[\"registry.terraform.io/hashicorp/google\"]",
              "instances": [
                {
                  "schema_version": 0,
                  "attributes": {
                    "id": "projects/xxx-xxx/managedZones/xxx--public/rrsets/*.net1.cluster.xxx--public.net.com./A",
                    "managed_zone": "xxx--public",
                    "name": "*.net1.cluster.xxx--public.net.com.",
                    "project": "xxx-xxx",
                    "rrdatas": [
                      "11.22.33.44"
                    ],
                    "timeouts": null,
                    "ttl": 300,
                    "type": "A"
                  },
                  "sensitive_attributes": [],
                  "private": "xxx",
                  "dependencies": [
                    "xxx"
                  ]
                }
              ]
            }
          ]
        },
        "output": {
          "version": 4,
          "terraform_version": "1.0.6",
          "serial": 635,
          "lineage": "6a9c2392-fdae-2b54-adcc-7366f262ffa4",
          "outputs": {
            "test": "test1"
          },
          "resources": [
            {
              "module": "module.resources",
              "mode": "data",
              "type": "google_client_config"
            },
            {
              "module": "module.xxx.module.module1[\"cluster\"]",
              "mode": "managed",
              "type": "google_dns_record_set",
              "name": "public_ip_ic_dns",
              "provider": "module.xxx.provider[\"registry.terraform.io/hashicorp/google\"]",
              "instances": [
                {
                  "schema_version": 0,
                  "attributes": {
                    "id": "projects/xxx-xxx/managedZones/xxx--public/rrsets/*.net1.cluster.xxx--public.net.com./A",
                    "managed_zone": "xxx--public",
                    "name": "*.net1.cluster.xxx--public.net.com.",
                    "project": "xxx-xxx",
                    "rrdatas": [
                      "11.22.33.44"
                    ],
                    "ttl": 300,
                    "type": "A"
                  },
                  "sensitive_attributes": [],
                  "private": "xxx",
                  "dependencies": [
                    "xxx"
                  ]
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 71428557
  },
  {
    "context": [
      "I'm trying to get the name and mac-address of a device by calling:\r\n\r\n    ./advancedapi.sh getDeviceKeys mac name\r\nthis should return the mac-address and name of the device.",
      "Here is my advancedapi.sh ... Users should be able to call any function from the API with as many arguments as they want.",
      "There are actually many ways to do this, but the simplest might be using the `--args` command-line option, as illustrated here:",
      "Here\u2019s an example that might be closer to what you\u2019re looking for. Using your sample JSON:\r\n\r\nFile: check2\r\n```\r\n#/bin/bash\r\njq -r '\r\n  def project($array):\r\n    . as $in | reduce $array[] as $k ([]; . + [$in[$k]]);\r\n  $ARGS.positional,\r\n  (.data[] | project($ARGS.positional))\r\n  | @csv\r\n' input.json --args \"${@}\" \r\n```\r\n```\r\n./check2 name mac\r\n\"name\",\"mac\"\r\n\"Test-Accesspoint\",\"ff:ec:ff:89:ff:58\"\r\n\r\n```"
    ],
    "utterance": "Return selected fields for each device, such as name and mac, given a list of field names as arguments.",
    "expressions": [
      "jq -r '\ndef project($array):\n  . as $in | reduce $array[] as $k ([]; . + [$in[$k]]);\n$ARGS.positional,\n(.data[] | project($ARGS.positional))\n| @csv\n' input.json --args name mac"
    ],
    "data": [
      {
        "input": {
          "meta": {
            "rc": "ok"
          },
          "data": [
            {
              "_id": "61a0da77f730e404af0edc3c",
              "ip": "10.19.31.120",
              "mac": "ff:ec:ff:89:ff:58",
              "name": "Test-Accesspoint"
            }
          ]
        },
        "output": [
          "\"name\",\"mac\"",
          "\"Test-Accesspoint\",\"ff:ec:ff:89:ff:58\""
        ]
      }
    ],
    "identifier": 71410229
  },
  {
    "context": [
      "I am looking to use jq to only grab the keys that contain \"vault\", so the output should be:",
      "\u2026 | jq 'to_entries | map(select(.key | startswith(\"vault\"))) | from_entries'",
      "Or use `with_entries(\u2026)` which is a builtin shortcut to `to_entries | map(\u2026) | from_entries`:",
      "\u2026 | jq 'with_entries(select(.key | startswith(\"vault\")))'",
      "{\n  \"vault.hashicorp.com/agent-cache-enable\": \"true\",\n  \"vault.hashicorp.com/agent-cache-use-auto-auth-token\": \"force\",\n  \"vault.hashicorp.com/agent-init-first\": \"true\",\n  \"vault.hashicorp.com/agent-inject\": \"true\",\n  \"vault.hashicorp.com/ca-cert\": \"/run/secrets/kubernetes.io/serviceaccount/ca.crt\",\n  \"vault.hashicorp.com/preserve-secret-case\": \"true\",\n  \"vault.hashicorp.com/role\": \"my-role\",\n  \"vault.hashicorp.com/secret-volume-path-a\": \"/var/path\",\n  \"vault.hashicorp.com/secret-volume-path-b\": \"/var/path\",\n  \"vault.hashicorp.com/secret-volume-path-c\": \"/var/path\",\n  \"vault.hashicorp.com/secret-volume-path-d\": \"/var/path\",\n  \"vault.hashicorp.com/secret-volume-path-e\": \"/var/path\"\n}"
    ],
    "utterance": "Filter the object to include only keys that start with 'vault'.",
    "expressions": [
      "to_entries | map(select(.key | startswith(\"vault\"))) | from_entries",
      "with_entries(select(.key | startswith(\"vault\")))"
    ],
    "data": [
      {
        "input": {
          "kubectl.kubernetes.io/restartedAt": "2022-03-09T16:09:47-08:00",
          "sidecar.istio.io/proxyCPU": "100m",
          "sidecar.istio.io/proxyCPULimit": "2",
          "sidecar.istio.io/proxyMemory": "128Mi",
          "sidecar.istio.io/proxyMemoryLimit": "1Gi",
          "traffic.sidecar.istio.io/excludeOutboundPorts": "8200",
          "vault.hashicorp.com/agent-cache-enable": "true",
          "vault.hashicorp.com/agent-cache-use-auto-auth-token": "force",
          "vault.hashicorp.com/agent-init-first": "true",
          "vault.hashicorp.com/agent-inject": "true",
          "vault.hashicorp.com/ca-cert": "/run/secrets/kubernetes.io/serviceaccount/ca.crt",
          "vault.hashicorp.com/preserve-secret-case": "true",
          "vault.hashicorp.com/role": "my-role",
          "vault.hashicorp.com/secret-volume-path-a": "/var/path",
          "vault.hashicorp.com/secret-volume-path-b": "/var/path",
          "vault.hashicorp.com/secret-volume-path-c": "/var/path",
          "vault.hashicorp.com/secret-volume-path-d": "/var/path",
          "vault.hashicorp.com/secret-volume-path-e": "/var/path"
        },
        "output": {
          "vault.hashicorp.com/agent-cache-enable": "true",
          "vault.hashicorp.com/agent-cache-use-auto-auth-token": "force",
          "vault.hashicorp.com/agent-init-first": "true",
          "vault.hashicorp.com/agent-inject": "true",
          "vault.hashicorp.com/ca-cert": "/run/secrets/kubernetes.io/serviceaccount/ca.crt",
          "vault.hashicorp.com/preserve-secret-case": "true",
          "vault.hashicorp.com/role": "my-role",
          "vault.hashicorp.com/secret-volume-path-a": "/var/path",
          "vault.hashicorp.com/secret-volume-path-b": "/var/path",
          "vault.hashicorp.com/secret-volume-path-c": "/var/path",
          "vault.hashicorp.com/secret-volume-path-d": "/var/path",
          "vault.hashicorp.com/secret-volume-path-e": "/var/path"
        }
      }
    ],
    "identifier": 71431880
  },
  {
    "context": [
      "can i define a variable and call the function name contained in the value of that variable?",
      "I want to call the function that is defined by the fp variable. so the result would be \"fp is here f1\"",
      "> can i define a variable and call the function name contained in the value of that variable?",
      "No. You\u2019d have to write a dispatcher."
    ],
    "utterance": "Call a function whose name is contained in a variable, so that setting the variable to 'f1' then calls 'f1'.",
    "expressions": [],
    "data": [
      {
        "input": null,
        "output": "\"fp is here f1\""
      }
    ],
    "identifier": 71450728
  },
  {
    "context": [
      "I want to parse a json file that is the output for the elasticsearch roles I configured on the cluster. Unfortunatelly its structure is different in some places, due to the fact that some role mappings were added manually and some roles mapping were added with API.",
      "I want to transform the above json to look like below, but the the 1st section has \"rules -> fields -> groups\" and the 2nd section has \"rules -> all -> fields -> groups\"",
      "Is there any way to parse with jq and eventually to transform to CSV format?",
      "You can use [`has`](https://stedolan.github.io/jq/manual/#has%28key%29) to check for the existence of a key called `all`:",
      "jq 'del(.rules) + {\n  GROUPS: (.rules | if has(\"all\") then .all[] else . end | .field.groups)\n}' input.json",
      "Another approach would be to make use of the [Error Suppression Operator]... in combination with the [Alternative Operator]...:\n\njq 'del(.rules) + {GROUPS: (.rules | .all[]? // . | .field.groups)}'"
    ],
    "utterance": "Normalize objects with differing locations for group membership, extracting the 'groups' value regardless of whether it appears under 'rules.field.groups' or 'rules.all[].field.groups', and placing it in a top-level 'GROUPS' field.",
    "expressions": [
      "del(.rules) + { GROUPS: (.rules | if has(\"all\") then .all[] else . end | .field.groups) }",
      "del(.rules) + {GROUPS: (.rules | .all[]? // . | .field.groups)}"
    ],
    "data": [
      {
        "input": {
          "MAPPING_NAME": "FOO_MAPPING",
          "roles": [
            "FOO_ROLE"
          ],
          "rules": {
            "field": {
              "groups": "CN=FO_SEC_GROUP,OU=foo,OU=example,DC=com"
            }
          }
        },
        "output": {
          "MAPPING_NAME": "FOO_MAPPING",
          "roles": [
            "FOO_ROLE"
          ],
          "GROUPS": "CN=FO_SEC_GROUP,OU=foo,OU=example,DC=com"
        }
      },
      {
        "input": {
          "MAPPING_NAME": "BAR_MAPPING",
          "roles": [
            "BAR_ROLE",
            "builtin_role"
          ],
          "rules": {
            "all": [
              {
                "field": {
                  "groups": "CN=BAR_SEC_GROUP,OU=bar,OU=example,DC=com"
                }
              }
            ]
          }
        },
        "output": {
          "MAPPING_NAME": "BAR_MAPPING",
          "roles": [
            "BAR_ROLE",
            "builtin_role"
          ],
          "GROUPS": "CN=BAR_SEC_GROUP,OU=bar,OU=example,DC=com"
        }
      }
    ],
    "identifier": 71438815
  },
  {
    "context": [
      "I want to pass string format from the command line of jq, instead of embedding the format in string interpolation.",
      "Let's say the format string is \"my string %s\". How to modify the following jq command to take the format string in its argument so that the output will be \"my string x\"?",
      "Having \"my string %s\" as a parameter string, you cannot use it for string interpolation, as string interpolation is a language construct, and jq does not provide an eval (or similar) function to evaluate a variable's content as code.",
      "What you can do instead is to (naively) replace %s with something else using sub or gsub:",
      "jq -r -e -n --arg f \"my string %s\" '$f | sub(\"%s\"; input)' <<< '\"x\"'",
      "my string x"
    ],
    "utterance": "Replace '%s' in a format string provided as a command line argument with the input value to produce a formatted string such as 'my string x'.",
    "expressions": [
      "$f | sub(\"%s\"; input)"
    ],
    "data": [
      {
        "input": "x",
        "output": "my string x"
      }
    ],
    "identifier": 71458511
  },
  {
    "context": [
      "I have error with scan function, why?",
      ".spec.selector | [scan(\"([0-9A-Za-z_]+) == '([0-9A-Za-z_]+)\") | {(.[0]): .[1]}]",
      "[\n  {\n    \"app\": \"nginx\"\n  }\n]"
    ],
    "utterance": "Extract key-value pairs from a string field matching the pattern key == 'value', returning objects for each match.",
    "expressions": [
      ".spec.selector | [scan(\"([0-9A-Za-z_]+) == '([0-9A-Za-z_]+)\") | {(.[0]): .[1]}]"
    ],
    "data": [
      {
        "input": {
          "spec": {
            "selector": "app == 'nginx'"
          }
        },
        "output": [
          {
            "app": "nginx"
          }
        ]
      }
    ],
    "identifier": 71465246
  },
  {
    "context": [
      "APP_URL=$(cat /tmp/output.json | jq -r '.app_url.value')",
      "I'm getting the following error in the GitHub Action logs: parse error: Invalid numeric literal at line 1, column 9",
      "output of `cat /tmp/output.json` is: /home/runner/work/_temp/2b622f60-be99-4a29-a295-593b06dde9a8/terraform-bin -chdir=terraform/live/dev output -json\n{\n  \"app_url\": {\n    \"sensitive\": false,\n    \"type\": \"string\",\n    \"value\": \"https://app.example.com\"\n  }\n}",
      "This tells me that `jq` can't parse the temporary file that I wrote the terraform JSON output to because it seems to be adding the command to the file itself:",
      "How can I get the terraform output as JSON and write it to a file without the extra header line that is causing the parse error?",
      "APP_URL=$(cat /tmp/output.json | jq -r '.app_url.value')"
    ],
    "utterance": "Extract the app_url value from output containing extra non-JSON header lines, ignoring any invalid header.",
    "expressions": [
      "jq -r '.app_url.value' <(tail -n +2 /tmp/output.json)"
    ],
    "data": [
      {
        "input": "/home/runner/work/_temp/2b622f60-be99-4a29-a295-593b06dde9a8/terraform-bin -chdir=terraform/live/dev output -json\n{\n  \"app_url\": {\n    \"sensitive\": false,\n    \"type\": \"string\",\n    \"value\": \"https://app.example.com\"\n  }\n}",
        "output": "https://app.example.com"
      }
    ],
    "identifier": 71462777
  },
  {
    "context": [
      "I want to sort this file on a given value, but I don't want to load it entirely in RAM.",
      "Having as many outputs as username is also good to me, if the method requires splitting the file.",
      "Here is a dummy example of what my input file looks like :",
      "{'username': 'user1', 'email': 'email1', 'value': '10'}",
      "{'username': 'user2', 'email': 'email2', 'value': '30'}",
      "...",
      "Here is the output I would like :",
      "{'username': 'user1', 'email': 'email1', 'value': '10'}",
      "{'username': 'user1', 'email': 'email1', 'value': '5'}",
      "...",
      "You can use the following:",
      "jq -r '\"\\( .username )\\u0000\\( tojson )\"' a.json |",
      "sort |",
      "jq -Rc '. / \"\\u0000\" | .[-1] | fromjson'"
    ],
    "utterance": "Sort a large newline-delimited file so that all entries for each username are grouped together, using minimal memory.",
    "expressions": [
      "jq -r '\"\\(.username)\\u0000\\(tojson)\"' a.json",
      "jq -Rc '. / \"\\u0000\" | .[-1] | fromjson'"
    ],
    "data": [
      {
        "input": [
          {
            "username": "user1",
            "email": "email1",
            "value": "10"
          },
          {
            "username": "user2",
            "email": "email2",
            "value": "30"
          },
          {
            "username": "user2",
            "email": "email2",
            "value": "30"
          },
          {
            "username": "user1",
            "email": "email1",
            "value": "5"
          },
          {
            "username": "user3",
            "email": "email3",
            "value": "15"
          },
          {
            "username": "user1",
            "email": "email1",
            "value": "40"
          },
          {
            "username": "user3",
            "email": "email1",
            "value": "40"
          }
        ],
        "output": [
          {
            "username": "user1",
            "email": "email1",
            "value": "10"
          },
          {
            "username": "user1",
            "email": "email1",
            "value": "40"
          },
          {
            "username": "user1",
            "email": "email1",
            "value": "5"
          },
          {
            "username": "user2",
            "email": "email2",
            "value": "30"
          },
          {
            "username": "user2",
            "email": "email2",
            "value": "30"
          },
          {
            "username": "user3",
            "email": "email1",
            "value": "40"
          },
          {
            "username": "user3",
            "email": "email3",
            "value": "15"
          }
        ]
      }
    ],
    "identifier": 71472327
  },
  {
    "context": [
      "I would like the following output to be:\r\n\r\n[\r\n  {\"name\":\"test\", \"data\":\"test_data\"}\r\n]\r\n",
      "let's assume for a moment that it is the first part until the underscore of the `name` from the input. The the following produces your required output:",
      ".items | map(\r\n  .metadata\r\n  | select(.random_field.\"foo/foo\" == \"true\")\r\n  | { name: .name|split(\"_\")|first, data: .name }\r\n)"
    ],
    "utterance": "Produce an array of objects each containing name as the part before the underscore of metadata.name and data as metadata.name for items where metadata.random_field[\"foo/foo\"] equals \"true\".",
    "expressions": [
      ".items | map(.metadata | select(.random_field.\"foo/foo\" == \"true\") | { name: .name|split(\"_\")|first, data: .name })"
    ],
    "data": [
      {
        "input": {
          "apiVersion": "v1",
          "items": [
            {
              "metadata": {
                "random_field": {
                  "foo/foo": "true"
                },
                "creationTimestamp": "2022-03-09T21:54:08Z",
                "name": "test_data"
              }
            }
          ]
        },
        "output": [
          {
            "name": "test",
            "data": "test_data"
          }
        ]
      }
    ],
    "identifier": 71490175
  },
  {
    "context": [
      "I want to transform it into a single json structure like this:\n\n    {\n        {\"ens1f0\": \"ens1f0v1\"},\n        {\"ens1f0\": \"ens1f0v0\"},\n        {\"ens1f1\": \"ens1f1v1\"},\n        {\"ens1f1\": \"ens1f1v0\"}\n    }",
      "I also want to add values with same keys as comma separated inside same key, so that will make above json look this this\n\n    {\n        {\"ens1f0\": \"ens1f0v1, ens1f0v0\"},\n        {\"ens1f1\": \"ens1f1v1, ens1f1v0\"}\n    }",
      "But I am losing data with this..as there are duplicate keys with differing values. How do I add it like:\n\n    {\n        \"ens1f0\": \"ens1f0v1,ens1f0v0\",\n        \"ens1f1\": \"ens1f1v1,ens1f1v0\",\n        \"ens2f1\": \"ens2f1v0\"\n    }",
      "jq -n '\n  reduce inputs as $in ({};\n    ($in|keys[0]) as $k | .[$k] += [$in[$k]] )\n  | map_values(join(\",\"))\n' vf.json"
    ],
    "utterance": "Combine lines with identical keys into a single object, joining their values as a comma-separated string for each key.",
    "expressions": [
      "jq -n '\n  reduce inputs as $in ({};\n    ($in|keys[0]) as $k | .[$k] += [$in[$k]] )\n  | map_values(join(\",\"))\n' vf.json"
    ],
    "data": [
      {
        "input": [
          {
            "ens1f0": "ens1f0v1"
          },
          {
            "ens1f0": "ens1f0v0"
          },
          {
            "ens1f1": "ens1f1v1"
          },
          {
            "ens1f1": "ens1f1v0"
          },
          {
            "ens2f1": "ens2f1v0"
          },
          {
            "ens2f0": "ens2f0v0"
          }
        ],
        "output": {
          "ens1f0": "ens1f0v1,ens1f0v0",
          "ens1f1": "ens1f1v1,ens1f1v0",
          "ens2f1": "ens2f1v0",
          "ens2f0": "ens2f0v0"
        }
      }
    ],
    "identifier": 71476376
  },
  {
    "context": [
      "I'm trying to come up with a bash script that would check if vulnerabilities length is null or not. If not, print the value of the vulnerabilities key.",
      "if `vulnerabilities` null, then jq will return null",
      "filter empty array: `.vulnerabilities | select(length > 0)`",
      "if (.vulnerabilities | length) > 0 then {vulnerabilities} else empty end"
    ],
    "utterance": "Return the vulnerabilities field only if its array is not empty.",
    "expressions": [
      ".vulnerabilities | select(length > 0)",
      "if (.vulnerabilities | length) > 0 then {vulnerabilities} else empty end",
      "select(.vulnerabilities != []).vulnerabilities"
    ],
    "data": [
      {
        "input": {
          "version": "14.0.4",
          "vulnerabilities": [
            {
              "id": "64e69d1185ecc48a1943141dcb6dbd628548e725f7cef70d57403c412321aaa0",
              "category": "secret_detection"
            }
          ]
        },
        "output": [
          {
            "id": "64e69d1185ecc48a1943141dcb6dbd628548e725f7cef70d57403c412321aaa0",
            "category": "secret_detection"
          }
        ]
      },
      {
        "input": {
          "version": "14.0.4",
          "vulnerabilities": []
        },
        "output": []
      }
    ],
    "identifier": 71476198
  },
  {
    "context": [
      "I want to divide the above JSON file into the following two files.",
      "jq .apps sample.json outputs only value.",
      "`jq '{apps}' sample.json`",
      "And likewise with `{test}`."
    ],
    "utterance": "Extract only the object with the 'apps' key and its value from the input so that the output contains { \"apps\": [...] }.",
    "expressions": [
      "{apps}"
    ],
    "data": [
      {
        "input": {
          "apps": [
            {
              "name": "app1"
            },
            {
              "name": "app2"
            },
            {
              "name": "app3"
            }
          ],
          "test": [
            {
              "name": "test1"
            },
            {
              "name": "test2"
            }
          ]
        },
        "output": {
          "apps": [
            {
              "name": "app1"
            },
            {
              "name": "app2"
            },
            {
              "name": "app3"
            }
          ]
        }
      }
    ],
    "identifier": 71490218
  },
  {
    "context": [
      "How to sort this code by amount in either jq or sed/awk ?",
      "if you want to restructure this object so keys are ordered by some condition, you could do this:",
      "to_entries | sort_by(.value.amount) | from_entries",
      "Reread the object as a collection of key/value pairs, sort the pairs by what you want, then recreate the object."
    ],
    "utterance": "Reorder the keys of an object so that entries are in ascending order of their 'amount' property.",
    "expressions": [
      "to_entries | sort_by(.value.amount) | from_entries"
    ],
    "data": [
      {
        "input": {
          "adfdasfdafdfds": {
            "amount": 43,
            "mints": [
              "adfdasffd",
              "dsafdsafdsfds"
            ]
          },
          "dfsfsdfdsf": {
            "amount": 1020,
            "mints": [
              "dfsfsads"
            ]
          },
          "sdfsdfdfgf": {
            "amount": 1,
            "mints": [
              "fsfdsfdfds"
            ]
          }
        },
        "output": {
          "sdfsdfdfgf": {
            "amount": 1,
            "mints": [
              "fsfdsfdfds"
            ]
          },
          "adfdasfdafdfds": {
            "amount": 43,
            "mints": [
              "adfdasffd",
              "dsafdsafdsfds"
            ]
          },
          "dfsfsdfdsf": {
            "amount": 1020,
            "mints": [
              "dfsfsads"
            ]
          }
        }
      }
    ],
    "identifier": 71490575
  },
  {
    "context": [
      "you are trying to reduce an input stream of JSON objects from `file.json` by comparing their `words` field's numeric content to a list of numbers stored in the bash array `wordDupArray`. More specifically, given a single input object, you want to pass it through to the output if `.words` holds a number that is not present in a list of numbers provided, or else drop it if the number *is* present in the list.",
      "jq --slurpfile list <(cat <<< \"${wordDupArray[@]}\") \\\n  'select([.words != $list[]] | all)' file.json",
      "jq --slurpfile list <(cat <<< \"${wordDupArray[@]}\") \\\n  'select(.words | IN($list[]) | not)' file.json"
    ],
    "utterance": "Filter objects so that only those whose 'words' field is not in a given list of numbers are selected.",
    "expressions": [
      "select([.words != $list[]] | all)",
      "select(.words | IN($list[]) | not)"
    ],
    "data": [
      {
        "input": [
          {
            "timestamp": "2022-03-09T12:30:23.329630917+01:00",
            "scheme": "http",
            "port": "80",
            "path": "/",
            "body-sha256": "0bfc0bdeb920ce4701f130e6e6a33c8aaf558fae44c7479cc1629930cb0f4535",
            "header-sha256": "d9522b92bb09e71b719804f522f0b3b49aa77974c8d79e644fb45a7b3327f73",
            "a": [
              "81.91.86.14"
            ],
            "url": "http://01.akce.omv.com:80",
            "input": "01.akce.omv.com",
            "location": "https://01.akce.omv.com/",
            "webserver": "openresty",
            "content-type": "text/html",
            "method": "GET",
            "host": "81.91.86.14",
            "content-length": 95,
            "status-code": 301,
            "response-time": "194.004475ms",
            "failed": false,
            "lines": 3,
            "words": 6
          },
          {
            "timestamp": "2022-03-09T12:30:23.355007661+01:00",
            "scheme": "http",
            "port": "80",
            "path": "/",
            "body-sha256": "d6285599bd6f2851fc17e0244ad212a58d8d539231f804f81b5b98289197afa0",
            "header-sha256": "96884ec058c78d0ea282a2d51be4ce0f5c7bc05d8fe3e8dd8f6fb73dd4fa2cd6",
            "a": [
              "81.91.86.14",
              "40.90.4.7",
              "64.4.48.7",
              "2603:1061::7",
              "2620:1ec:8ec::7"
            ],
            "url": "http://09-mail2.akce.omv.com:80",
            "input": "09-mail2.akce.omv.com",
            "location": "https://09-mail2.akce.omv.com/",
            "webserver": "openresty",
            "content-type": "text/html",
            "method": "GET",
            "host": "81.91.86.14",
            "content-length": 101,
            "status-code": 301,
            "response-time": "233.377898ms",
            "failed": false,
            "lines": 3,
            "words": 6
          },
          {
            "timestamp": "2022-03-09T12:30:23.450849812+01:00",
            "scheme": "http",
            "port": "80",
            "path": "/",
            "body-sha256": "c186820e328bf631a2943f77e52e9e8319ddfefade6d308a2a22ef996176bbe6",
            "header-sha256": "61e4f3139518b49cac86b77a4f9f06da98d53f2eb12dbff574b5a0ea66327478",
            "a": [
              "81.91.86.14"
            ],
            "url": "http://09-server2.akce.omv.com:80",
            "input": "09-server2.akce.omv.com",
            "location": "https://09-server2.akce.omv.com/",
            "webserver": "openresty",
            "content-type": "text/html",
            "method": "GET",
            "host": "81.91.86.14",
            "content-length": 103,
            "status-code": 301,
            "response-time": "268.856986ms",
            "failed": false,
            "lines": 3,
            "words": 6
          }
        ],
        "output": []
      }
    ],
    "identifier": 71421978
  },
  {
    "context": [
      "How i can convert this metric array into the non-array object?",
      "Is there any way to do that in single query?",
      "If no keys collide, you could integrate the `.metric` subarray's items into the actual record:",
      "jq -r '\n  .observations[] |= (. + .metric | del(.metric))\n  | (.observations[0] | keys_unsorted), (.observations[] | map(values))\n  | @csv\n' file.json",
      "If they happen to collide, add some prefix to their names to disambiguate:",
      "jq -r '\n  .observations[] |= (. + (.metric | with_entries(.key |= \"metric_\\(.)\")) | del(.metric))\n  | (.observations[0] | keys_unsorted), (.observations[] | map(values))\n  | @csv\n' file.json"
    ],
    "utterance": "Produce a CSV where each row contains all top-level observation fields and metric fields flattened into a single row per observation.",
    "expressions": [
      ".observations[] |= (. + .metric | del(.metric))\n| (.observations[0] | keys_unsorted), (.observations[] | map(values))\n| @csv",
      ".observations[] |= (. + (.metric | with_entries(.key |= \"metric_\\(.)\")) | del(.metric))\n| (.observations[0] | keys_unsorted), (.observations[] | map(values))\n| @csv"
    ],
    "data": [
      {
        "input": {
          "observations": [
            {
              "stationID": "IBONIE3",
              "tz": "Europe/Warsaw",
              "obsTimeUtc": "2021-07-31T21:59:50Z",
              "obsTimeLocal": "2021-07-31 23:59:50",
              "epoch": 1627768790,
              "lat": 52.203785,
              "lon": 20.618021,
              "solarRadiationHigh": 0,
              "uvHigh": 0,
              "winddirAvg": 257,
              "humidityHigh": 74,
              "humidityLow": 71,
              "humidityAvg": 71,
              "qcStatus": 1,
              "metric": {
                "tempHigh": 20,
                "tempLow": 20,
                "tempAvg": 20,
                "windspeedHigh": 8,
                "windspeedLow": 0,
                "windspeedAvg": 2,
                "windgustHigh": 12,
                "windgustLow": 0,
                "windgustAvg": 3,
                "dewptHigh": 15,
                "dewptLow": 15,
                "dewptAvg": 15,
                "windchillHigh": 20,
                "windchillLow": 20,
                "windchillAvg": 20,
                "heatindexHigh": 20,
                "heatindexLow": 20,
                "heatindexAvg": 20,
                "pressureMax": 994.58,
                "pressureMin": 993.91,
                "pressureTrend": 0,
                "precipRate": 0,
                "precipTotal": 0
              }
            }
          ]
        },
        "output": "\"stationID\",\"tz\",\"obsTimeUtc\",\"obsTimeLocal\",\"epoch\",\"lat\",\"lon\",\"solarRadiationHigh\",\"uvHigh\",\"winddirAvg\",\"humidityHigh\",\"humidityLow\",\"humidityAvg\",\"qcStatus\",\"tempHigh\",\"tempLow\",\"tempAvg\",\"windspeedHigh\",\"windspeedLow\",\"windspeedAvg\",\"windgustHigh\",\"windgustLow\",\"windgustAvg\",\"dewptHigh\",\"dewptLow\",\"dewptAvg\",\"windchillHigh\",\"windchillLow\",\"windchillAvg\",\"heatindexHigh\",\"heatindexLow\",\"heatindexAvg\",\"pressureMax\",\"pressureMin\",\"pressureTrend\",\"precipRate\",\"precipTotal\"\n\"IBONIE3\",\"Europe/Warsaw\",\"2021-07-31T21:59:50Z\",\"2021-07-31 23:59:50\",1627768790,52.203785,20.618021,0,0,257,74,71,71,1,20,20,20,8,0,2,12,0,3,15,15,15,20,20,20,20,20,20,994.58,993.91,0,0,0"
      }
    ],
    "identifier": 71438278
  },
  {
    "context": [
      "The following two iso8601 strings both mean the beginning of the respective day. But since EST has been changed to EDT between the two dates, the second time string is interpreted as 1am instead of 0am. Is there a way to let jq be aware of the daylight saving when processing an iso8601 string?",
      "$ jq fromdateiso8601 <<< '\"2022-03-11T05:00:00Z\"'\n1646974800",
      "$ jq fromdateiso8601 <<< '\"2022-03-14T04:00:00Z\"'\n1647234000",
      "$ TZ=America/New_York date --date=@1646974800\nFri Mar 11 00:00:00 EST 2022",
      "$ TZ=America/New_York date --date=@1647234000\nMon Mar 14 01:00:00 EDT 2022",
      "`2022-03-14T04:00:00Z` is `1647230400`, not `1647234000`.",
      "$ jq fromdateiso8601 <<<'\"2022-03-14T04:00:00Z\"'\n1647230400"
    ],
    "utterance": "Parse an ISO 8601 date string into a Unix timestamp, considering daylight saving time changes in America/New_York.",
    "expressions": [
      "fromdateiso8601"
    ],
    "data": [
      {
        "input": "\"2022-03-11T05:00:00Z\"",
        "output": 1646974800
      },
      {
        "input": "\"2022-03-14T04:00:00Z\"",
        "output": 1647230400
      }
    ],
    "identifier": 71490304
  },
  {
    "context": [
      "I want to extract key which is ec2-instance id and value which is combination of tags that needs to be added.",
      "You want to parse a string like `\"Key=a,Value=b Key=c,Value=d\"` into a JSON object.",
      "Given these assumptions, the following snippet parses a string in the above format into a JSON object:",
      "jq '[ split(\" \") | .[] | split(\",\") | { (.[]|select(startswith(\"Key=\"))[4:]) : .[]|select(startswith(\"Value=\"))[6:] } ] | add | . // {}'"
    ],
    "utterance": "Convert each EC2 instance's value string in the format 'Key=a,Value=b Key=c,Value=d' into an object mapping keys to values for a given account and region.",
    "expressions": [
      "[ split(\" \") | .[] | split(\",\") | { (.[]|select(startswith(\"Key=\"))[4:]): .[]|select(startswith(\"Value=\"))[6:] } ] | add | . // {}"
    ],
    "data": [
      {
        "input": "Key=a,Value=c key=2,Value=3",
        "output": {
          "a": "c",
          "2": "3"
        }
      },
      {
        "input": "Key=t,Value=n",
        "output": {
          "t": "n"
        }
      }
    ],
    "identifier": 71491565
  },
  {
    "context": [
      "How can I (generically) transform the input file below to output file below, using jq:",
      "**Input file:**\n```\n[{\"a\": 1, \"b\": 10},\n {\"a\": 2, \"d\": \"fred\", \"e\": 30}]\n```\n**Output file:**\n```\nINSERT INTO mytab (a,b) VALUES (1,10);\nINSERT INTO mytab (a,d,e) VALUES (2,\"fred\",30);\n```",
      "jq --raw-output '\n  .[]| to_entries | map(.key) as $k | map(.value) as $v | \n    \"INSERT INTO mytab (\\($k | join(\",\"))) VALUES (\\($v | @csv ));\"' \n"
    ],
    "utterance": "Convert each object to an SQL INSERT statement, with columns as keys and values as values, quoting strings as shown.",
    "expressions": [
      ".[]| to_entries | map(.key) as $k | map(.value) as $v | \"INSERT INTO mytab (\\($k | join(\",\"))) VALUES (\\($v | @csv ));\""
    ],
    "data": [
      {
        "input": [
          {
            "a": 1,
            "b": 10
          },
          {
            "a": 2,
            "d": "fred",
            "e": 30
          }
        ],
        "output": [
          "INSERT INTO mytab (a,b) VALUES (1,10);",
          "INSERT INTO mytab (a,d,e) VALUES (2,\"fred\",30);"
        ]
      }
    ],
    "identifier": 71492517
  },
  {
    "context": [
      "how can I update servers object in my json using jq?",
      "I need to have servers like that:",
      "\"servers\": [ { \"url\": \"http://localhost:5000\", \"description\": \"Localhost server\" } ],",
      "jq '.servers = [{url:\"http://localhost:5000\", description: \"Localhost server\"}]'"
    ],
    "utterance": "Replace the servers property so its value is an array with an object where url is \"http://localhost:5000\" and description is \"Localhost server\".",
    "expressions": [
      ".servers = [{url:\"http://localhost:5000\", description: \"Localhost server\"}]"
    ],
    "data": [
      {
        "input": {
          "tags": [],
          "servers": [],
          "components": {
            "securitySchemes": {
              "cookie": {
                "type": "apiKey",
                "in": "cookie",
                "name": "store",
                "description": "Store API"
              }
            }
          }
        },
        "output": {
          "tags": [],
          "servers": [
            {
              "url": "http://localhost:5000",
              "description": "Localhost server"
            }
          ],
          "components": {
            "securitySchemes": {
              "cookie": {
                "type": "apiKey",
                "in": "cookie",
                "name": "store",
                "description": "Store API"
              }
            }
          }
        }
      }
    ],
    "identifier": 71493664
  },
  {
    "context": [
      "It is possible to define a custom format/escape function, say `@sql`?",
      "you need to understand that `@csv`, `@sh` etc aren&#39;t separate functions from jq&#39;s point of view. They&#39;re all implemented by the `format/1` function.",
      "You can redefine this function, and lo and behold jq will use it for formatting!",
      "def oldformat(fstring):\n    format(fstring);\ndef format(fstring):\n    if fstring==\"sparkle\" then\n        \".:!\" + (tostring) + \"!:.\"\n    else\n        oldformat(fstring)\n    end\n;\n[1,2,3]|(@sparkle,@json,@sh)"
    ],
    "utterance": "Define a custom escape function named @sparkle that wraps the value with .:! and !:.",
    "expressions": [
      "def oldformat(fstring):\n    format(fstring);\ndef format(fstring):\n    if fstring==\"sparkle\" then\n        \".:!\" + (tostring) + \"!:.\"\n    else\n        oldformat(fstring)\n    end\n;\n[1,2,3]|@sparkle"
    ],
    "data": [
      {
        "input": [
          1,
          2,
          3
        ],
        "output": ".:![1,2,3]!:."
      }
    ],
    "identifier": 71492865
  },
  {
    "context": [
      "However, what I really need is to have this data in CSV format.",
      "But none of the examples I&#39;ve found for generating CSV data with jq involve selecting specific columns or re-naming those columns.",
      "If you only want a subset of them, just change the `$cols` variable to be what columns you want from the data.",
      "You might want to separate the value mapping from this since you have some nested values.",
      "[\"oracle_id\", \"id\", \"rarity\", \"set\", \"price\", \"scryfall_uri\", \"image_uri\", \"digital\", \"promo\", \"variation\"],\n(.[] | [.oracle_id, .id, .rarity, .set, .prices.usd, .scryfall_uri, .image_uris.art_crop, .digital, .promo, .variation])\n  | @csv"
    ],
    "utterance": "Convert the selected fields 'oracle_id', 'id', 'rarity', 'set', '.prices.usd', 'scryfall_uri', '.image_uris.art_crop', 'digital', 'promo', and 'variation' from each object in the data to a CSV with a header row.",
    "expressions": [
      "[\"oracle_id\", \"id\", \"rarity\", \"set\", \"price\", \"scryfall_uri\", \"image_uri\", \"digital\", \"promo\", \"variation\"],\n(.[] | [.oracle_id, .id, .rarity, .set, .prices.usd, .scryfall_uri, .image_uris.art_crop, .digital, .promo, .variation])\n  | @csv"
    ],
    "identifier": 71505606
  },
  {
    "context": [
      "I\u2019m trying to select records where FromPort is 80 and CidrIp is 0.0.0.0/0 within the same element of the record.",
      "Here is a solution that selects a group if there is **at least one** item in the `.IpPermissions` array that has a match for `.FromPort` **and at least one** match for `.CidrIp` in the `.IpRanges` array:\n\n~~~sh\njq '\n  .SecurityGroups[] | select(\n    any(.IpPermissions[]; .FromPort == 80 and\n      any(.IpRanges[]; .CidrIp == \"0.0.0.0/0\")\n    )\n  )\n' data.json",
      "You can use parenthesis `()` and `and` appropriately to filter like this: `(.FromPort==80 and (.IpRanges[] | .CidrIp==\"0.0.0.0/0\" ))`. By doing this, we make sure that **both** conditions are matched by an entry in `IpPermissions`.",
      "Now you can see only `Group3` is outputted.",
      "Or you could use `any/2` as pmf suggested.\n\nFilter\n```\n.SecurityGroups[] \n| select(any(.IpPermissions[]; .FromPort==80 \nand any(.IpRanges[]; .CidrIp==\"0.0.0.0/0\")))\n```"
    ],
    "utterance": "Select security groups that have an IpPermissions entry with FromPort 80 and a CidrIp of 0.0.0.0/0 in its IpRanges.",
    "expressions": [
      ".SecurityGroups[] | select(any(.IpPermissions[]; .FromPort == 80 and any(.IpRanges[]; .CidrIp == \"0.0.0.0/0\")))",
      ".SecurityGroups | map(select(.IpPermissions[] | (.FromPort==80 and (.IpRanges[] | .CidrIp==\"0.0.0.0/0\" ))))"
    ],
    "data": [
      {
        "input": {
          "SecurityGroups": [
            {
              "GroupName": "Group1",
              "IpPermissions": [
                {
                  "FromPort": 80,
                  "IpProtocol": "tcp",
                  "IpRanges": [
                    {
                      "CidrIp": "1.2.3.4/24"
                    }
                  ]
                },
                {
                  "FromPort": 6789,
                  "IpProtocol": "tcp",
                  "IpRanges": [
                    {
                      "CidrIp": "1.2.3.4/24"
                    },
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ]
                }
              ]
            },
            {
              "GroupName": "Group2",
              "IpPermissions": [
                {
                  "FromPort": 443,
                  "IpProtocol": "tcp",
                  "IpRanges": [
                    {
                      "CidrIp": "1.2.3.4/24"
                    },
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ]
                },
                {
                  "FromPort": 6788,
                  "IpProtocol": "tcp",
                  "IpRanges": [
                    {
                      "CidrIp": "1.2.3.4/24"
                    }
                  ]
                }
              ]
            },
            {
              "GroupName": "Group3",
              "IpPermissions": [
                {
                  "FromPort": 80,
                  "IpProtocol": "tcp",
                  "IpRanges": [
                    {
                      "CidrIp": "1.2.3.4/24"
                    },
                    {
                      "CidrIp": "0.0.0.0/0"
                    }
                  ]
                },
                {
                  "FromPort": 6789,
                  "IpProtocol": "tcp",
                  "IpRanges": [
                    {
                      "CidrIp": "1.2.3.4/24"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          {
            "GroupName": "Group3",
            "IpPermissions": [
              {
                "FromPort": 80,
                "IpProtocol": "tcp",
                "IpRanges": [
                  {
                    "CidrIp": "1.2.3.4/24"
                  },
                  {
                    "CidrIp": "0.0.0.0/0"
                  }
                ]
              },
              {
                "FromPort": 6789,
                "IpProtocol": "tcp",
                "IpRanges": [
                  {
                    "CidrIp": "1.2.3.4/24"
                  }
                ]
              }
            ]
          }
        ]
      }
    ],
    "identifier": 71438490
  },
  {
    "context": [
      "res=$(echo $js | jq '.results[].media[].gif.url') # res contains the url of the gif that we searched",
      "Add `-r` to the jq command (for raw-output).",
      "url2=$(curl $url | jq -r '.results[].media[].gif.url') # this have whole json result from tenor"
    ],
    "utterance": "Extract all values of gif URLs from the results media list corresponding to gifs in the response.",
    "expressions": [
      ".results[].media[].gif.url",
      ".results[].media[].gif.url // empty",
      ".results[].media[].gif.url? // empty"
    ],
    "identifier": 71516052
  },
  {
    "context": [
      "I wish to retrieve the `CODE` value for each ACCOUNT",
      "ie for \n`000545342981` i wish to have `xdxd3456532fok234sss0` returned and \n`xdff3678223frt244swe4` for `000545341211`",
      "If each account contains only one code, you can do :",
      "jq -r '.block       | to_entries[] | \"\\(.key) \\(.value[0].CODE)\"' input.json"
    ],
    "utterance": "Output each account's key and its corresponding CODE value as key value pairs.",
    "expressions": [
      ".block | to_entries[] | \"\u007f(.key) \u007f(.value[0].CODE)\""
    ],
    "data": [
      {
        "input": {
          "block": {
            "000545342981": [
              {
                "CODE": "xdxd3456532fok234sss0"
              },
              {
                "STATE": "COMPLETE"
              }
            ],
            "000545341211": [
              {
                "CODE": "xdff3678223frt244swe4"
              },
              {
                "STATE": "RUNNING"
              }
            ]
          }
        },
        "output": [
          "000545342981 xdxd3456532fok234sss0",
          "000545341211 xdff3678223frt244swe4"
        ]
      }
    ],
    "identifier": 71513261
  },
  {
    "context": [
      "I'm performing a query on vault API to list all the entities by their Ids and trying extract alias name from `aliases.name`, however, due to the different map name in each iteration I'm not able to extract the value.",
      "If you are trying to extract a stream of ojects with just the `name` field:",
      "\u2026 | jq -c \".data.key_info[] | .aliases[] | {name}\"",
      "If you just need the values, use the `-r` option:",
      "\u2026 | jq -r \".data.key_info[].aliases[].name\"",
      "**Expected output**\n\n    \"name\": \"John Doe\"\n    \"name\": \"Jane Smith\""
    ],
    "utterance": "Extract all alias names from each entity's aliases, regardless of the entity ID keys.",
    "expressions": [
      ".data.key_info[] | .aliases[] | {name}",
      ".data.key_info[].aliases[].name"
    ],
    "data": [
      {
        "input": {
          "data": {
            "key_info": {
              "923104b3-910c-05b1-b448-fcg3d67276e1": {
                "aliases": [
                  {
                    "id": "6a6f2dc4-2cd8-1881-662f-b5955e765e0d",
                    "mount_accessor": "auth_oidc_053b2418",
                    "mount_path": "auth/oidc/",
                    "mount_type": "oidc",
                    "name": "John Doe"
                  }
                ],
                "name": "entity_402ea123"
              },
              "ba6b00c4-36gg-gd86-86bf-13d731588241": {
                "aliases": [
                  {
                    "id": "3ji408b2-4548-75f7-8c41-9901b77af7d1",
                    "mount_accessor": "auth_oidc_053b2418",
                    "mount_path": "auth/oidc/",
                    "mount_type": "oidc",
                    "name": "Jane Smith"
                  }
                ],
                "name": "entity_98746ae4"
              }
            }
          }
        },
        "output": [
          {
            "name": "John Doe"
          },
          {
            "name": "Jane Smith"
          }
        ]
      }
    ],
    "identifier": 71515734
  },
  {
    "context": [
      "I want to get the result that ec2 instance does not have specific Key(in my example, it is env or appname)",
      "I have been searching and reading that I need to use either `ascii_downcase` or `ascii_uppercase`, but keep failing applying. How can I improve my jq statement so that I can filter ec2 instances which do not have specific Key case-insenstiviely(like, `env` or `ENV` or `Env`)?",
      "map(select( any(.Tags[]; .Key | ascii_downcase | IN( \"env\", \"appname\")) | not))"
    ],
    "utterance": "Find all EC2 instances that do not have any tag key equal to 'env' or 'appname', case-insensitively.",
    "expressions": [
      "map(select( any(.Tags[]; .Key | ascii_downcase | IN(\"env\", \"appname\")) | not))"
    ],
    "data": [
      {
        "input": [
          {
            "InstanceId": "t-1234",
            "Tags": [
              {
                "Key": "Name",
                "Value": "Foo"
              },
              {
                "Key": "env",
                "Value": "prod"
              }
            ]
          },
          {
            "InstanceId": "t-1235",
            "Tags": [
              {
                "Key": "Name",
                "Value": "Bar"
              },
              {
                "Key": "Env",
                "Value": "prod"
              },
              {
                "Key": "AppName",
                "Value": "BarApp"
              }
            ]
          },
          {
            "InstanceId": "t-1236",
            "Tags": [
              {
                "Key": "Name",
                "Value": "Bar"
              }
            ]
          }
        ],
        "output": [
          {
            "InstanceId": "t-1234",
            "Tags": [
              {
                "Key": "Name",
                "Value": "Foo"
              },
              {
                "Key": "env",
                "Value": "prod"
              }
            ]
          },
          {
            "InstanceId": "t-1236",
            "Tags": [
              {
                "Key": "Name",
                "Value": "Bar"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 71517646
  },
  {
    "context": [
      "Now, for every path without its last part, I would like to find only the latest ones according to the `modified` field (which are always on the top because of the sorting). Then, output that path including its last part again.",
      "In other words, for this example data the output should be:\r\n\r\n```\r\nother/foo/1.15.1\r\na/b/foo/1.0.3-SNAPSHOT\r\na/b/c/0.1.1\r\n```",
      "jq -r '[.results[]\n          | .short = .path[0:(.path | rindex(\"/\"))]\n       ]\n       | group_by(.short)[]\n       | max_by(.modified).path\n      ' file.json",
      "jq -n -r 'foreach (inputs | .results| .[]) as $k (\n                 {};\n    \n                 .[$k.path | sub(\"/[^/]*$\"; \"\")]+=1;\n    \n                 if .[$k.path | sub(\"/[^/]*$\"; \"\")] ==1 then\n                     $k.path\n                 else\n                     empty\n                 end\n             )'"
    ],
    "utterance": "For each group of entries sharing the same path prefix except the last segment, return only the entry with the most recent modified field based on an already-descending sort, outputting its full path.",
    "expressions": [
      "[.results[]\n  | .short = .path[0:(.path | rindex(\"/\"))]\n] | group_by(.short)[]\n  | max_by(.modified).path",
      "foreach (.results[] ) as $k ({};\n  .[$k.path | sub(\"/[^/]*$\"; \"\")] += 1;\n  if .[$k.path | sub(\"/[^/]*$\"; \"\")] == 1 then $k.path else empty end\n)"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "path": "other/foo/1.15.1",
              "modified": "2022-02-09T13:45:34.638Z"
            },
            {
              "path": "other/foo/1.15.0",
              "modified": "2022-02-09T10:00:40.681Z"
            },
            {
              "path": "a/b/foo/1.0.3-SNAPSHOT",
              "modified": "2022-03-04T19:07:30.262Z"
            },
            {
              "path": "a/b/c/0.1.1",
              "modified": "2022-01-10T15:12:00.597Z"
            },
            {
              "path": "a/b/c/0.1.0",
              "modified": "2022-01-07T18:05:23.158Z"
            },
            {
              "path": "a/b/c/0.0.9",
              "modified": "2021-12-06T10:29:31.161Z"
            }
          ]
        },
        "output": [
          "other/foo/1.15.1",
          "a/b/foo/1.0.3-SNAPSHOT",
          "a/b/c/0.1.1"
        ]
      }
    ],
    "identifier": 71492946
  },
  {
    "context": [
      "I want to take this and make it into a newline-delimited list of all the things tagged \"name\" like this:\n```\nNewport Beach\nNipomo\nNorco\nNorth Glendale\nNorth Highlands\n```",
      "I tried to do this on the command line using a tool I found called jq, which I though would work by writing something like\n```\ncat world_cities.json | jq '.name' > cities_list.txt\n```\nbut I got an error that said \"jq: error (at <stdin>:0): Cannot index array with string \"name\".\"",
      "\"$ jq -r '.[].name' world_cities.json\nNewport Beach\nNipomo\nNorco\nNorth Glendale\nNorth Highlands\"",
      "You can access the elements with `.[]`: `.` is the array itself and `[]` gives its elements. Then `.name` gives you each element's name.",
      "Finally, use `-r` to have jq output raw strings without quotes."
    ],
    "utterance": "Output a newline-delimited list of the values associated with the name key for each object in the top-level array.",
    "expressions": [
      ".[].name"
    ],
    "data": [
      {
        "input": [
          {
            "country": "United States",
            "geonameid": 5376890,
            "name": "Newport Beach",
            "subcountry": "California"
          },
          {
            "country": "United States",
            "geonameid": 5377100,
            "name": "Nipomo",
            "subcountry": "California"
          },
          {
            "country": "United States",
            "geonameid": 5377199,
            "name": "Norco",
            "subcountry": "California"
          },
          {
            "country": "United States",
            "geonameid": 5377613,
            "name": "North Glendale",
            "subcountry": "California"
          },
          {
            "country": "United States",
            "geonameid": 5377640,
            "name": "North Highlands",
            "subcountry": "California"
          }
        ],
        "output": [
          "Newport Beach",
          "Nipomo",
          "Norco",
          "North Glendale",
          "North Highlands"
        ]
      }
    ],
    "identifier": 71518883
  },
  {
    "context": [
      "I'm trying to simply update an array, while also printing out the full JSON body. Whenever I update the array, I can only output the JSON object that Im updating rather than printing the entire JSON document, plus the updates.",
      "Desired Output:\n\n{\n  \"data\": [\n    {\n      \"alert\": {\n        \"notifications\": [\n          {\n            \"uid\": \"foo123\"\n          },\n          {\n            \"uid\": \"bar123\"\n          }\n        ]\n      },\n      \"title\": \"Test\"\n    },\n    {\n      \"alert\": {\n        \"notifications\": [\n          {\n            \"uid\": \"foo1\"\n          },\n          {\n            \"uid\": \"bar1\"\n          }\n        ]\n      },\n      \"title\": \"Test2\"\n    }\n  ]\n}",
      "Try updating |= the data field with a map:",
      "jq --arg title \"$t\" --arg array \"[$array]\" \\\n  '.data |= map(select(.title == $title).alert.notifications = ($array | fromjson))'",
      "Alternatively, wrap the LHS of the assigment into parentheses to retain the context:",
      "jq --arg title \"$t\" --arg array \"[$array]\" \\\n  '(.data[] | select(.title == $title).alert.notifications) = ($array | fromjson)'"
    ],
    "utterance": "Replace the notifications array for all data objects with title equal to Test, keeping the rest of the structure unchanged.",
    "expressions": [
      ".data |= map(select(.title == $title).alert.notifications = ($array | fromjson))",
      "(.data[] | select(.title == $title).alert.notifications) = ($array | fromjson)"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "alert": {
                "notifications": [
                  {
                    "uid": "foo"
                  },
                  {
                    "uid": "bar"
                  }
                ]
              },
              "title": "Test"
            },
            {
              "alert": {
                "notifications": [
                  {
                    "uid": "foo1"
                  },
                  {
                    "uid": "bar1"
                  }
                ]
              },
              "title": "Test2"
            }
          ]
        },
        "output": {
          "data": [
            {
              "alert": {
                "notifications": [
                  {
                    "uid": "foo123"
                  },
                  {
                    "uid": "bar123"
                  }
                ]
              },
              "title": "Test"
            },
            {
              "alert": {
                "notifications": [
                  {
                    "uid": "foo1"
                  },
                  {
                    "uid": "bar1"
                  }
                ]
              },
              "title": "Test2"
            }
          ]
        }
      }
    ],
    "identifier": 71517828
  },
  {
    "context": [
      "However, I need to put the array in a var and supply it on the fly instead, like:",
      "array='{\"uid\": \"foo\" },{\"uid\": \"bar\"}'",
      "jq -r --arg title \"$t\" --arg array \"$array\" 'select(.title == $title) | .alert.notifications = [$array]'",
      "But that results in this undesired output",
      "Use `--argjson` (instead of `--arg`) for JSON input.",
      "You need to wrap it into brackets to make it an array",
      "array='[{\"uid\": \"foo\" }, {\"uid\": \"bar\"}]'",
      "jq --arg title \"$t\" --argjson array \"$array\" \\\n  'select(.title == $title) | .alert.notifications = $array'",
      "you can use the `fromjson` builtin to convert a JSON-encoded string into actual JSON",
      "jq --arg title \"$t\" --arg array \"$array\" \\\n  'select(.title == $title) | .alert.notifications = ($array | fromjson)'"
    ],
    "utterance": "Replace the .alert.notifications array with the contents of a shell variable containing an array of objects, for objects where .title equals a specified value.",
    "expressions": [
      "select(.title == $title) | .alert.notifications = $array",
      "select(.title == $title) | .alert.notifications = ($array | fromjson)"
    ],
    "data": [
      {
        "input": {
          "alert": {},
          "title": "Test"
        },
        "output": {
          "alert": {
            "notifications": [
              {
                "uid": "foo"
              },
              {
                "uid": "bar"
              }
            ]
          },
          "title": "Test"
        }
      }
    ],
    "identifier": 71507448
  },
  {
    "context": [
      "assuming i have the stage name stored in a variable how do i retrieve the \"durationMillis\" value from that stage",
      "export BUILD_NUMBER='72'; export STAGE1=\"CLEANUP WORKSTATION\";",
      "cat file.json | jq '.[] | select(.id==env.BUILD_NUMBER) | .stages | .[] | select(.name | contains(env.STAGE1)) | .durationMillis'"
    ],
    "utterance": "Retrieve the durationMillis value for the stage whose name matches the value of an environment variable, from the job whose id matches an environment variable.",
    "expressions": [
      ".[] | select(.id==env.BUILD_NUMBER) | .stages | .[] | select(.name | contains(env.STAGE1)) | .durationMillis"
    ],
    "data": [
      {
        "input": [
          {
            "_links": {
              "self": {
                "href": "/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/72/wfapi/describe"
              }
            },
            "id": "72",
            "name": "#72",
            "status": "SUCCESS",
            "startTimeMillis": 1646952992850,
            "endTimeMillis": 1646953018448,
            "durationMillis": 25598,
            "queueDurationMillis": 24,
            "pauseDurationMillis": 0,
            "stages": [
              {
                "_links": {
                  "self": {
                    "href": "/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/72/execution/node/8/wfapi/describe"
                  }
                },
                "id": "8",
                "name": "CLEANUP WORKSTATION",
                "execNode": "",
                "status": "SUCCESS",
                "startTimeMillis": 1646953001559,
                "durationMillis": 157,
                "pauseDurationMillis": 0
              },
              {
                "_links": {
                  "self": {
                    "href": "/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/72/execution/node/12/wfapi/describe"
                  }
                },
                "id": "12",
                "name": "GIT CLONE",
                "execNode": "",
                "status": "SUCCESS",
                "startTimeMillis": 1646953001716,
                "durationMillis": 302,
                "pauseDurationMillis": 0
              }
            ]
          },
          {
            "_links": {
              "self": {
                "href": "/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/71/wfapi/describe"
              }
            },
            "id": "71",
            "name": "#71",
            "status": "SUCCESS",
            "startTimeMillis": 1646952745744,
            "endTimeMillis": 1646952770031,
            "durationMillis": 24287,
            "queueDurationMillis": 19,
            "pauseDurationMillis": 0,
            "stages": [
              {
                "_links": {
                  "self": {
                    "href": "/jenkins/cag-sw-jenkins/job/test/job/test-hagay-elk-kv/71/execution/node/8/wfapi/describe"
                  }
                },
                "id": "8",
                "name": "CLEANUP WORKSTATION",
                "execNode": "",
                "status": "SUCCESS",
                "startTimeMillis": 1646952754330,
                "durationMillis": 203,
                "pauseDurationMillis": 0
              }
            ]
          }
        ],
        "output": 157
      }
    ],
    "identifier": 71432160
  },
  {
    "context": [
      "I want to return the first element which has a keyword that can be found in the string.",
      "In this case I would like to have the element with the id `2345`, because the keyword `\"blue\"` occurs in the string, and it is the first match.",
      "jq --arg v \"The sky is blue.\" 'first(.[] | select(.keywords as $k | $v | match($k[])))'",
      "jq --arg str 'the sky is blue' 'first(.[] | select(.keywords | any(inside($str))))'"
    ],
    "utterance": "Return the first element in an array whose keywords include a word appearing in the string 'The sky is blue.'.",
    "expressions": [
      "jq --arg v \"The sky is blue.\" 'first(.[] | select(.keywords as $k | $v | match($k[])))'",
      "jq --arg str 'The sky is blue.' 'first(.[] | select(.keywords | any(inside($str))))'"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1234,
            "name": "Entry 1",
            "keywords": [
              "orange",
              "yellow"
            ]
          },
          {
            "id": 2345,
            "name": "Entry 2",
            "keywords": [
              "red",
              "blue",
              "pink"
            ]
          },
          {
            "id": 3456,
            "name": "Entry 3",
            "keywords": [
              "green",
              "blue",
              "black"
            ]
          }
        ],
        "output": {
          "id": 2345,
          "name": "Entry 2",
          "keywords": [
            "red",
            "blue",
            "pink"
          ]
        }
      }
    ],
    "identifier": 71528675
  },
  {
    "context": [
      "Currently, I am hardcoding this with the parsing of the JSON file with jq:",
      "echo \"NAME=$(jq -r '.name' variables.json)\" >> $GITHUB_ENV",
      "...etc",
      "**How can I \"for loop\" through this process?**",
      "Afterwards, I want to check if the variables entered manually through a workflow_dispatch run of the job match what are in the variables.json file. If they don't match, I want to update the json file with the new manually entered value:",
      "run: echo \"$( jq '.name = ${{github.event.inputs.age}}' variables.json )\" > variables.json",
      "**Similarly, how do I loop through this process?**"
    ],
    "utterance": "Extract all top-level key-value pairs from a file and output as ENV_VAR=VALUE pairs, one per line, for use in a shell script.",
    "expressions": [
      "jq -r 'to_entries|map(\"\u001b[1m\"){.key}={.value}\u001b[0m\")|.[]' variables.json"
    ],
    "data": [
      {
        "input": {
          "name": "Alice",
          "age": 30,
          "weight": 55
        },
        "output": [
          "name=Alice",
          "age=30",
          "weight=55"
        ]
      }
    ],
    "identifier": 71523580
  },
  {
    "context": [
      "I want to add entries in an array to a JSON object as below",
      "I would like to have an output that looks like below:",
      "Update `|=` the `.Changes` array by adding to its `first` item's `ResourceRecordSet` field the second file's array items `input[]`:",
      "jq '.Changes |= [first | .ResourceRecordSet += input[]]' outer.json records.json",
      "Note: If `outer.json`'s `ResourceRecordSet` is always empty, you may as well just make an assignment `=` instead of an updating addition `+=`."
    ],
    "utterance": "For each entry in the records array, create a new object in the Changes array with Action set to DELETE and ResourceRecordSet set to that entry's contents, preserving the original Comment field.",
    "expressions": [
      ".Changes |= [first | .ResourceRecordSet += input[]]"
    ],
    "data": [
      {
        "input": {
          "outer.json": {
            "Comment": "Delete record sets for $cluster_name",
            "Changes": [
              {
                "Action": "DELETE",
                "ResourceRecordSet": {}
              }
            ]
          },
          "records.json": [
            {
              "Name": "abcde_svcx.$cluster_name.domain.com.",
              "Type": "TXT",
              "TTL": 300,
              "ResourceRecords": [
                {
                  "Value": "\"heritage=external-dns,external-dns/owner=$cluster_name,external-dns/resource=service/svcx/svcx-cluster\""
                }
              ]
            },
            {
              "Name": "svcx.$cluster_name.domain.com.",
              "Type": "A",
              "AliasTarget": {
                "HostedZoneId": "123456789",
                "DNSName": "some-value.elb.us-east-2.amazonaws.com.",
                "EvaluateTargetHealth": true
              }
            }
          ]
        },
        "output": {
          "Comment": "Delete record sets for $cluster_name",
          "Changes": [
            {
              "Action": "DELETE",
              "ResourceRecordSet": {
                "Name": "abcde_svcx.$cluster_name.domain.com.",
                "Type": "TXT",
                "TTL": 300,
                "ResourceRecords": [
                  {
                    "Value": "\"heritage=external-dns,external-dns/owner=$cluster_name,external-dns/resource=service/svcx/svcx-cluster\""
                  }
                ]
              }
            },
            {
              "Action": "DELETE",
              "ResourceRecordSet": {
                "Name": "svcx.$cluster_name.domain.com.",
                "Type": "A",
                "AliasTarget": {
                  "HostedZoneId": "123456789",
                  "DNSName": "some-value.elb.us-east-2.amazonaws.com.",
                  "EvaluateTargetHealth": true
                }
              }
            }
          ]
        }
      }
    ],
    "identifier": 71556455
  },
  {
    "context": [
      "I am not able to find a way to extract a json block by position.That is to say if I want to print just the last json block or a random json block like 5th or 6th or 5th & 6th only, is there a `jq` option or a way to achieve this please?",
      "Last: `last`",
      "Last: .[-1]",
      "5th: `.[4]`",
      "6th: `.[5]`",
      "5th and 6th (as array) `.[4:6]`",
      "n-th, where $n is specified on the command line (0-based indexing): jq --argjson n $n '.[$n]'",
      "$m-th and $n-th (with 0-based indexing): '.[$m, $n]'",
      "An element chosen pseudo-randomly (assuming a bash or bash-like shell and that the array is not too long):",
      "jq --argjson prn $RANDOM '\n  if length > 32767 then \"Sorry - this algorithm is too simplistic.\" | error\n  else .[$prn % length]\n  end\n'",
      "An alternative way to make a pseudo-random choice without assuming a bash-like environment:",
      "jq '\n  if length > 1e6 then \"Sorry - this algorithm is too simplistic.\" | error\n  else \n   (now|tostring|sub(\".*[.]\",\"\")|tonumber) as $n\n   | .[$n % length]\n  end'"
    ],
    "utterance": "Extract one or more elements from an array by their positions, including the last element, a specific element like the 5th or 6th, and a random element.",
    "expressions": [
      "last",
      ".[-1]",
      ".[4]",
      ".[5]",
      ".[4:6]",
      "[.[4], .[5]]",
      ".[4:6][]",
      ".[4], .[5]",
      "jq --argjson n $n '.[$n]'",
      ".[$m, $n]",
      "jq --argjson prn $RANDOM 'if length > 32767 then \"Sorry - this algorithm is too simplistic.\" | error else .[$prn % length] end'",
      "jq 'if length > 1e6 then \"Sorry - this algorithm is too simplistic.\" | error else (now|tostring|sub(\".*[.]\",\"\")|tonumber) as $n | .[$n % length] end'"
    ],
    "data": [
      {
        "input": [
          {
            "field1": "value1",
            "field2": "value2",
            "field3": "value3"
          },
          {
            "field1": "value1",
            "field2": "value2",
            "field3": "value3"
          },
          {
            "field1": "value1",
            "field2": "value2",
            "field3": "value3"
          },
          {
            "field1": "value1",
            "field2": "value2",
            "field3": "value3"
          }
        ]
      }
    ],
    "identifier": 71552299
  },
  {
    "context": [
      "I have two json's that are a list of objects that share the same key and I am trying to combine them into one json using jq. The expected output is a single json that contains a list of the combined objects in list form.",
      "Combined Json Based on Id",
      "Use the [SQL-Style Operators](https://stedolan.github.io/jq/manual/#SQL-StyleOperators) `JOIN` and `INDEX`",
      "jq 'JOIN(INDEX(inputs[];.Id);.[];.Id;add)' json1 json2"
    ],
    "utterance": "Combine two arrays of objects into a single array by merging objects with the same Id key, resulting in objects containing all fields from both arrays.",
    "expressions": [
      "JOIN(INDEX(inputs[];.Id);.[];.Id;add)"
    ],
    "data": [
      {
        "input": [
          [
            {
              "Id": "1",
              "FirstName": "firstName1",
              "LastName": "lastName1"
            },
            {
              "Id": "2",
              "FirstName": "firstName2",
              "LastName": "lastName2"
            },
            {
              "Id": "3",
              "FirstName": "firstName2",
              "LastName": "lastName3"
            }
          ],
          [
            {
              "School": "School1",
              "Id": "1",
              "Degree": "Degree1"
            },
            {
              "School": "School2",
              "Id": "2",
              "Degree": "Degree2"
            },
            {
              "School": "School3",
              "Id": "3",
              "Degree": "Degree3"
            }
          ]
        ],
        "output": [
          {
            "Id": "1",
            "FirstName": "firstName1",
            "LastName": "lastName1",
            "School": "School1",
            "Degree": "Degree1"
          },
          {
            "Id": "2",
            "FirstName": "firstName2",
            "LastName": "lastName2",
            "School": "School2",
            "Degree": "Degree2"
          },
          {
            "Id": "3",
            "FirstName": "firstName2",
            "LastName": "lastName3",
            "School": "School3",
            "Degree": "Degree3"
          }
        ]
      }
    ],
    "identifier": 71563226
  },
  {
    "context": [
      "How to test for empty input and do something different depending on whether the input is empty or not?",
      "One way would be to use the `-s` option and test for the empty array:",
      "jq -s 'if . == [] then \"empty\" else .[0].data end' < /dev/null",
      "jq -Rs 'fromjson? // error(\"Bad input\") | .data' < /dev/null",
      "You can use\n\n```sh\njq -ne 'input? // null'\n```",
      "If you also want to check that `.data` isn't missing and isn't `null` (or `false`), you can use\n\n```sh\njq -ne 'input? // null | .data'\n```"
    ],
    "utterance": "Detect if the input is empty and return a custom result or error; if input has a .data field, output its value.",
    "expressions": [
      "jq -s 'if . == [] then \"empty\" else .[0].data end'",
      "jq -Rs 'fromjson? // error(\"Bad input\") | .data'",
      "jq -ne 'input? // null'",
      "jq -ne 'input? // null | .data'"
    ],
    "data": [
      {
        "input": "",
        "output": "empty"
      },
      {
        "input": "{ \"data\": 1 }",
        "output": 1
      },
      {
        "input": "{ \"other\": 1 }",
        "output": null
      }
    ],
    "identifier": 71565651
  },
  {
    "context": [
      "My goal is to **obtain a merged file every hour with the average load on all available data**, like that (just considering the 2 files above):",
      "Here\u0019s a solution for an arbitrary number of input files. It first divides each value by the number of input files, and then adds them all up retaining the keys",
      "jq -s '\n  .[][][] /= length\n  | reduce (.[] | to_entries[]) as $u ({};\n      reduce ($u.value | to_entries[]) as $s (.;\n        .[$u.key][$s.key] += $s.value\n      )\n    )\n' file*",
      "The division may also be shifted into the addition by using a variable at the beginning instead:",
      "jq -s '\n  length as $c\n  | reduce (.[] | to_entries[]) as $u ({};\n      reduce ($u.value | to_entries[]) as $s (.;\n        .[$u.key][$s.key] += $s.value / $c\n      )\n    )\n' file*"
    ],
    "utterance": "Compute the average value of each user's server usage across multiple files, merging all keys into a single structure and filling missing user/server combinations as needed.",
    "expressions": [
      "jq -s '\n  .[][][] /= length\n  | reduce (.[] | to_entries[]) as $u ({};\n      reduce ($u.value | to_entries[]) as $s (.;\n        .[$u.key][$s.key] += $s.value\n      )\n    )\n' file*",
      "jq -s '\n  length as $c\n  | reduce (.[] | to_entries[]) as $u ({};\n      reduce ($u.value | to_entries[]) as $s (.;\n        .[$u.key][$s.key] += $s.value / $c\n      )\n    )\n' file*"
    ],
    "data": [
      {
        "input": [
          {
            "user1": {
              "server1": 7.2,
              "server2": 10.3
            },
            "user2": {
              "server1": 15
            }
          },
          {
            "user1": {
              "server1": 8.5,
              "server3": 20.5
            },
            "user3": {
              "server1": 28
            }
          }
        ],
        "output": {
          "user1": {
            "server1": 7.85,
            "server2": 5.15,
            "server3": 10.25
          },
          "user2": {
            "server1": 7.5
          },
          "user3": {
            "server1": 14
          }
        }
      }
    ],
    "identifier": 71557998
  },
  {
    "context": [
      "My json response is like this.",
      "{\n  \"level\": \"info\",\n  \"timestamp\": \"2022-03-21T16:10:27.060Z\",\n  \"msg\": \"starting test\",\n}\n{\n  \"level\": \"warn\",\n  \"timestamp\": \"2022-03-21T16:10:27.060Z\",\n  \"msg\": \"message 2\"\n}\n{\n  \"level\": \"error\",\n  \"timestamp\": \"2022-03-21T16:10:27.060Z\",\n  \"msg\": \"message 3\"\n}\n",
      "I want to extract.\nEither 3rd message (or nth message) or the message associated with error",
      "Use `select` to filter by condition\njq 'select(.level == \"error\")'\n{\n  \"level\": \"error\",\n  \"timestamp\": \"2022-03-21T16:10:27.060Z\",\n  \"msg\": \"message 3\"\n}",
      "To extract the message, use the `-r` option\njq -r 'select(.level == \"error\").msg'\nmessage 3",
      "If you want to access the nth object, you may want to use a structure whose items you can count. Using the `-s` option would turn the input stream into an array. Using the `--argjson` option enables you using an external (JSON) value for reference:",
      "jq -sr --argjson n 2 '.[$n].msg'\nmessage 3",
      "To directly address the nth element of a stream, use the `nth` function, in combination with `inputs` and the `-n` option to address the entire stream at once:",
      "jq -nr --argjson n 2 'nth($n;inputs).msg'\nmessage 3"
    ],
    "utterance": "Return the message field of either the nth object or the object where level equals error from a series of JSON objects provided as separate objects, not as an array.",
    "expressions": [
      "select(.level == \"error\").msg",
      "-s '.[N].msg'",
      "-sr --argjson n N '.[$n].msg'",
      "-nr --argjson n N 'nth($n;inputs).msg'"
    ],
    "data": [
      {
        "input": [
          {
            "level": "info",
            "timestamp": "2022-03-21T16:10:27.060Z",
            "msg": "starting test"
          },
          {
            "level": "warn",
            "timestamp": "2022-03-21T16:10:27.060Z",
            "msg": "message 2"
          },
          {
            "level": "error",
            "timestamp": "2022-03-21T16:10:27.060Z",
            "msg": "message 3"
          }
        ],
        "output": "message 3"
      }
    ],
    "identifier": 71562848
  },
  {
    "context": [
      "I tried to get the Id: if the name of the plant is corn-1 and the price is 20 then print the Id",
      "jq -C 'select(.Plants[] | (.Name == \"corn-1\" and .Price == \"20\")).Id'",
      "To get it only once, you can use",
      "jq -C 'select(.Plants | any(.Name == \"corn-1\" and .Price == \"20\")).Id'"
    ],
    "utterance": "Return the Id when any plant has Name equal to \"corn-1\" and Price equal to \"20\".",
    "expressions": [
      "select(.Plants[] | (.Name == \"corn-1\" and .Price == \"20\")).Id",
      "select(.Plants | any(.Name == \"corn-1\" and .Price == \"20\")).Id"
    ],
    "data": [
      {
        "input": {
          "Id": "Category-1",
          "Plants": [
            {
              "Name": "corn-1",
              "Price": "20"
            },
            {
              "Name": "corn-2",
              "Price": "10"
            },
            {
              "Name": "corn-3",
              "Price": "5"
            }
          ]
        },
        "output": "Category-1"
      }
    ],
    "identifier": 71579394
  },
  {
    "context": [
      "It returns a list of elements that contain a value in $BL",
      "I want to return all those that are not in $BL, so I use | not",
      "for reference $BL is and array on email address, trying to make an api call and return all elements that don't have an email listed in $BL",
      "The solution is to use `any` or `all` to aggregate these boolean values.",
      ".rows[] | select(any(.cells[]; .value | IN($BL[])) | not)"
    ],
    "utterance": "Return all rows where none of the cell values are in the array $BL.",
    "expressions": [
      ".rows[] | select(any(.cells[]; .value | IN($BL[])) | not)"
    ],
    "identifier": 71580794
  },
  {
    "context": [
      "I would like to compare two json files and report differencies but I am interested in keys only and **not** values. So for example the \"json-diff\" between the following two files ... **should report** that there is missing key: - `http.test` but **should not report** that the following keys have different values: - `http.swagger.enabled` - `http.scalingFactors`",
      "jq -c '\n [paths(scalars)] as $f1\n | [input | paths(scalars)] as $f2\n | ($f1 - $f2) + ($f2 - $f1)' file1.json file2.json",
      "def p: [paths(scalars) | map(select(type==\"string\"))] | unique;\np as $f1\n| (input | p) as $f2\n| ($f1 - $f2) + ($f2 - $f1)\n| .[]"
    ],
    "utterance": "Report keys present in one file but not the other, ignoring any differences in values.",
    "expressions": [
      "[paths(scalars)] as $f1 | [input | paths(scalars)] as $f2 | ($f1 - $f2) + ($f2 - $f1)",
      "def p: [paths(scalars) | map(select(type==\"string\"))] | unique; p as $f1 | (input | p) as $f2 | ($f1 - $f2) + ($f2 - $f1) | .[]"
    ],
    "data": [
      {
        "input": [
          {
            "http": {
              "https": true,
              "swagger": {
                "enabled": false
              },
              "scalingFactors": [
                0.1,
                0.2
              ]
            }
          },
          {
            "http": {
              "https": true,
              "swagger": {
                "enabled": true
              },
              "scalingFactors": [
                0.1,
                0.1
              ],
              "test": true
            }
          }
        ],
        "output": [
          [
            "http",
            "test"
          ]
        ]
      }
    ],
    "identifier": 71576552
  },
  {
    "context": [
      "I select the fields I need with the command jq 'if .spec.selector == \"all()\" then \"{}\" else (scan(\"([0-9A-Za-z_]+) == '([0-9A-Za-z_]+)\") | {(.[0]): .[1]}) end | {selector: .}'",
      "But if I change the field to .spec.selector: \"app =='nginx'\" then I get an error - jq: error (at <stdin>:39): object ({\"apiVersio...) cannot be matched, as it is not a string",
      "You're applying `scan` to the wrong thing.",
      "if .spec.selector == \"all()\" then\n   \"{}\"\nelse\n   .spec.selector | \n   scan(\"([0-9A-Za-z_]+) == '([0-9A-Za-z_]+)\") |\n   { (.[0]): .[1] }\nend"
    ],
    "utterance": "If the value of .spec.selector is \"all()\", output an empty object as a string; otherwise, extract key and value pairs matching key =='value' from .spec.selector and output as an object.",
    "expressions": [
      "if .spec.selector == \"all()\" then \"{}\" else .spec.selector | scan(\"([0-9A-Za-z_]+) == '([0-9A-Za-z_]+)\") | { (.[0]): .[1] } end"
    ],
    "data": [
      {
        "input": {
          "apiVersion": "projectcalico.org/v3",
          "kind": "NetworkPolicy",
          "metadata": {
            "name": "allow-tcp-6379",
            "namespace": "production"
          },
          "spec": {
            "selector": "all()"
          }
        },
        "output": "{}"
      },
      {
        "input": {
          "apiVersion": "projectcalico.org/v3",
          "kind": "NetworkPolicy",
          "metadata": {
            "name": "allow-tcp-6379",
            "namespace": "production"
          },
          "spec": {
            "selector": "app =='nginx'"
          }
        },
        "output": {
          "app": "nginx"
        }
      }
    ],
    "identifier": 71575557
  },
  {
    "context": [
      "but how can I assign two new different values like 7  and 3  to the two a fields in the objects in the array?",
      "To achieve your goal, you will have to iterate over either array indices or the aligned elements.",
      "reduce ([3,7] | to_entries[]) as $i (.; .[$i.key].a = $i.value)",
      "[., [3,7]] | [transpose[] | first + {a:last}]"
    ],
    "utterance": "Assign the values 3 and 7 to the field 'a' of the first and second objects in the array, respectively.",
    "expressions": [
      "reduce ([3,7] | to_entries[]) as $i (.; .[$i.key].a = $i.value)",
      "[., [3,7]] | [transpose[] | first + {a:last}]"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1,
            "b": "john"
          },
          {
            "a": 2,
            "b": "mark"
          }
        ],
        "output": [
          {
            "a": 3,
            "b": "john"
          },
          {
            "a": 7,
            "b": "mark"
          }
        ]
      }
    ],
    "identifier": 71586980
  },
  {
    "context": [
      "Sample Input\r\n\r\n    [1,2,3,4,5,6,7,8,9]",
      "Output\r\n\r\n    [[1,2,3,4],[5,6,7,8],[9]]",
      "shorthand, handy method anything else?",
      "jq -c --argjson n 4 '[while(. != []; .[$n:])[:$n]]'",
      "jq -nc --argjson n 4 '[1,2,3,4,5,6,7,8,9] | [_nwise($n)]'"
    ],
    "utterance": "Split a list of numbers into sub-arrays of 4 elements each, with the last sub-array containing any remaining elements.",
    "expressions": [
      ". as $input | reduce range(0; ($input | length); $g) as $r ([]; . + [$input[$r:($r+$g)]] )",
      "[while(. != []; .[$n:])[:$n]]",
      "[_nwise($n)]"
    ],
    "data": [
      {
        "input": [
          1,
          2,
          3,
          4,
          5,
          6,
          7,
          8,
          9
        ],
        "output": [
          [
            1,
            2,
            3,
            4
          ],
          [
            5,
            6,
            7,
            8
          ],
          [
            9
          ]
        ]
      }
    ],
    "identifier": 71589807
  },
  {
    "context": [
      "Append location array with new element (I don't see any need for updating, but \"name\" would be the field to key off of)",
      "Instead you'll want the following :",
      "jq --argjson element \"$element\" '.locations += $element.locations'"
    ],
    "utterance": "Append a new object to the locations array, using data from another object with a locations field containing an array.",
    "expressions": [
      ".locations += $element.locations"
    ],
    "data": [
      {
        "input": {
          "locations": [
            {
              "name": "home",
              "address": "123 Main St, MyTown MyState",
              "latitude": null,
              "longitude": null,
              "gridId": null,
              "gridX": null,
              "gridY": null,
              "countyUGC": null,
              "zoneUGC": null,
              "stationId": null
            }
          ]
        }
      }
    ],
    "identifier": 71590931
  },
  {
    "context": [
      "irrespective of the path of key-value of JaegerAgentHost, I should be able to replace the value of it with my variable",
      "One way would be to use walk.",
      "walk(if type == \"object\" and has(\"JaegerAgentHost\") then .JaegerAgentHost = $host else . end)",
      "An alternative would be to use .. and |=:",
      "(..|objects|select(.JaegerAgentHost).JaegerAgentHost) |= $host",
      "You could pass in the value using the --arg command-line option, e.g.",
      "jq --arg host jaeger.app ....."
    ],
    "utterance": "Replace the value of every JaegerAgentHost key, no matter its location within the data structure, with a specified variable value.",
    "expressions": [
      "walk(if type == \"object\" and has(\"JaegerAgentHost\") then .JaegerAgentHost = $host else . end)",
      "(..|objects|select(.JaegerAgentHost).JaegerAgentHost) |= $host"
    ],
    "data": [
      {
        "input": {
          "Settings": {
            "JaegerServiceSettings": {
              "JaegerAgentHost": "jaeger.apps.internal",
              "JaegerAgentPort": "6831"
            }
          }
        },
        "output": {
          "Settings": {
            "JaegerServiceSettings": {
              "JaegerAgentHost": "jaeger.app",
              "JaegerAgentPort": "6831"
            }
          }
        }
      },
      {
        "input": {
          "JaegerServiceSettings": {
            "JaegerAgentHost": "jaeger.apps.internal",
            "JaegerAgentPort": "6831"
          }
        },
        "output": {
          "JaegerServiceSettings": {
            "JaegerAgentHost": "jaeger.app",
            "JaegerAgentPort": "6831"
          }
        }
      },
      {
        "input": {
          "JaegerAgentHost": "jaeger.apps.internal",
          "JaegerAgentPort": "6831"
        },
        "output": {
          "JaegerAgentHost": "jaeger.app",
          "JaegerAgentPort": "6831"
        }
      }
    ],
    "identifier": 71592108
  },
  {
    "context": [
      "Now you can read in that stream with jq, using the `-s` option to convert it into a proper array.",
      "jq -s . state.json"
    ],
    "utterance": "Convert a file containing a stream of objects into an array.",
    "expressions": [
      "jq -s . state.json"
    ],
    "data": [
      {
        "input": [
          {
            "cluster": "eks-b",
            "asgname": "eks-1234",
            "minSize": "0",
            "DesiredCapacity": "0",
            "MaxSize": "0"
          },
          {
            "cluster": "eks-b",
            "asgname": "eks-1234",
            "minSize": "0",
            "DesiredCapacity": "0",
            "MaxSize": "0"
          },
          {
            "cluster": "dev",
            "asgname": "eks-12345",
            "minSize": "0",
            "DesiredCapacity": "0",
            "MaxSize": "0"
          },
          {
            "cluster": "dev",
            "asgname": "eks-1234",
            "minSize": "0",
            "DesiredCapacity": "0",
            "MaxSize": "0"
          },
          {
            "cluster": "eks-a",
            "asgname": "eks-1234",
            "minSize": "0",
            "DesiredCapacity": "0",
            "MaxSize": "0"
          },
          {
            "cluster": "eks-a",
            "asgname": "eks-1323",
            "minSize": "0",
            "DesiredCapacity": "0",
            "MaxSize": "0"
          }
        ],
        "output": [
          {
            "cluster": "eks-b",
            "asgname": "eks-1234",
            "minSize": "0",
            "DesiredCapacity": "0",
            "MaxSize": "0"
          },
          {
            "cluster": "eks-b",
            "asgname": "eks-1234",
            "minSize": "0",
            "DesiredCapacity": "0",
            "MaxSize": "0"
          },
          {
            "cluster": "dev",
            "asgname": "eks-12345",
            "minSize": "0",
            "DesiredCapacity": "0",
            "MaxSize": "0"
          },
          {
            "cluster": "dev",
            "asgname": "eks-1234",
            "minSize": "0",
            "DesiredCapacity": "0",
            "MaxSize": "0"
          },
          {
            "cluster": "eks-a",
            "asgname": "eks-1234",
            "minSize": "0",
            "DesiredCapacity": "0",
            "MaxSize": "0"
          },
          {
            "cluster": "eks-a",
            "asgname": "eks-1323",
            "minSize": "0",
            "DesiredCapacity": "0",
            "MaxSize": "0"
          }
        ]
      }
    ],
    "identifier": 71544639
  },
  {
    "context": [
      "I don't understand why the `sub()` command does not replace \"%s\" with \"my string\" in the first jq command below. How to make it work?",
      "You have lost the input context. Save it in a variable (eg. `. as $dot`) to reference it later (eg. `$dot.desc`):",
      "$ jq -r --arg format '|%s|' '. as $dot | $format | sub(\"%s\"; $dot.desc)' <<< '{\"desc\": \"my string\"}'",
      "You can use null input `-n` :",
      "jq -nr --arg format '|%s|' '$format | sub(\"%s\"; input.desc)' <<< '{\"desc\": \"my string\"}'"
    ],
    "utterance": "Replace '%s' in the string '|%s|' with the value of the 'desc' field from the object {\"desc\": \"my string\"}.",
    "expressions": [
      ". as $dot | $format | sub(\"%s\"; $dot.desc)",
      "$format | sub(\"%s\"; input.desc)"
    ],
    "data": [
      {
        "input": {
          "desc": "my string"
        },
        "output": "|my string|"
      }
    ],
    "identifier": 71610877
  },
  {
    "context": [
      "I want to aggregate key values by key from some newline delimited json.",
      "Below is a sample input, note that it includes arrays.",
      "My desired output is below, essentially I get a listing of all keys in the structure, including array indices, with a sorted count by key value.",
      "You could use the `--stream` option to read in the big input in smaller pieces",
      "jq --stream -n '\n  {stats: (reduce (1 | truncate_stream(inputs)) as $i ({};\n    if ($i | has(1)) then .\"\\($i[0] | join(\".\"))\".\"\\($i[1])\" += 1 else . end\n  ))}\n' input.json",
      "def summary(stream):\n   reduce stream as [$p, $v] ({};\n      ($p|join(\".\")) as $q\n      | if .[$q] then .[$q][$v|tostring] += 1\n      else .[$q] = {($v|tostring): 1}\n      end);\n\n{stats: summary(inputs.content\n        | paths(scalars) as $p\n        | [$p, getpath($p)]) }"
    ],
    "utterance": "Aggregate the occurrence count of each scalar value for every possible key path (including array indices) beneath the 'content' object in a newline-delimited data set.",
    "expressions": [
      "jq --stream -n '{stats: (reduce (1 | truncate_stream(inputs)) as $i ({}; if ($i | has(1)) then .\"\\($i[0] | join(\".\"))\".\"\\($i[1])\" += 1 else . end))}' input.json",
      "def summary(stream):\n   reduce stream as [$p, $v] ({};\n      ($p|join(\".\")) as $q\n      | if .[$q] then .[$q][$v|tostring] += 1\n      else .[$q] = {($v|tostring): 1}\n      end);\n\n{stats: summary(inputs.content\n        | paths(scalars) as $p\n        | [$p, getpath($p)]) }"
    ],
    "data": [
      {
        "input": [
          {
            "content": {
              "user": {
                "name": "Bill",
                "items": [
                  {
                    "name": "shovel",
                    "details": {
                      "heavy": false
                    }
                  },
                  {
                    "name": "hammer"
                  }
                ],
                "details": {
                  "age": 60
                }
              }
            }
          },
          {
            "content": {
              "user": {
                "name": "Bill",
                "items": [
                  {
                    "name": "shovel",
                    "details": {
                      "heavy": false
                    }
                  },
                  {
                    "name": "hammer"
                  }
                ],
                "details": {
                  "age": 21
                }
              }
            }
          },
          {
            "content": {
              "user": {
                "name": "Alice",
                "items": [
                  {
                    "name": "hammer",
                    "details": {
                      "heavy": true
                    }
                  },
                  {
                    "name": "shovel"
                  }
                ],
                "details": {
                  "age": 30
                }
              }
            }
          }
        ],
        "output": {
          "stats": {
            "user.name": {
              "Bill": 2,
              "Alice": 1
            },
            "user.items.0.name": {
              "shovel": 2,
              "hammer": 1
            },
            "user.items.0.details.heavy": {
              "false": 2,
              "true": 1
            },
            "user.items.1.name": {
              "hammer": 2,
              "shovel": 1
            },
            "user.details.age": {
              "60": 1,
              "21": 1,
              "30": 1
            }
          }
        }
      }
    ],
    "identifier": 71517326
  },
  {
    "context": [
      "I have a function in bash ```psql_json()``` that hits a postgres database and returns a json. I can not edit this bash function but it injects a postgres statement into this this query which is then sent to the db:",
      "However, this function returns a weirdly formatted json string as seen below:",
      "{\\\"id\\\":1,\\\"firstName\\\":\\\"firstName1\\\",\\\"lastName\\\":\\\"lastName1\\\"}\\n",
      "{\\\"id\\\":2,\\\"firstName\\\":\\\"firstName2\\\",\\\"lastName\\\":\\\"lastName2\\\"}",
      "Now when I try to put this json as is into jq, I get the following error:",
      "Is there any way I can get string representation of the json above into jq in a clean way to process it or would I need to clean/edit the string in bash?",
      "You could fix the input using jq or a text-processing tool such as [tag:sed]:",
      "< weird.json jq -R 'sub(\"^\";\"\\\"\") | sub(\"$\";\"\\\"\") | fromjson | fromjson'",
      "or",
      "< weird.json sed -e 's/^/\"/' -e 's/$/\"/' | jq -R 'fromjson|fromjson'",
      "With your input, the result in both cases is:",
      "{",
      "  \"id\": 1,",
      "  \"firstName\": \"firstName1\",",
      "  \"lastName\": \"lastName1\"",
      "}",
      "{",
      "  \"id\": 2,",
      "  \"firstName\": \"firstName2\",",
      "  \"lastName\": \"lastName2\"",
      "}"
    ],
    "utterance": "Parse each line containing a string-encoded JSON object with escaped quotes so they become proper objects for further querying.",
    "expressions": [
      "jq -R 'sub(\"^\";\"\\\"\") | sub(\"$\";\"\\\"\") | fromjson | fromjson'",
      "jq -R 'fromjson|fromjson'"
    ],
    "data": [
      {
        "input": "{\\\"id\\\":1,\\\"firstName\\\":\\\"firstName1\\\",\\\"lastName\\\":\\\"lastName1\\\"}\n{\\\"id\\\":2,\\\"firstName\\\":\\\"firstName2\\\",\\\"lastName\\\":\\\"lastName2\\\"}\n",
        "output": [
          {
            "id": 1,
            "firstName": "firstName1",
            "lastName": "lastName1"
          },
          {
            "id": 2,
            "firstName": "firstName2",
            "lastName": "lastName2"
          }
        ]
      }
    ],
    "identifier": 71605342
  },
  {
    "context": [
      "So essentially, I would like something like this: \r\n\r\n    aws cloudwatch describe-alarms --query \"MetricAlarms[?AlarmName contains($filteredQueueName)]\"\r\n\r\n\r\n\r\nwhere `$filteredQueueName` is the name of the current queue I want to compare.",
      "I read about the command contains() on the `jq` manual page but I struggle to apply it in context.",
      "Consider this script which fetches alarm configuration when **AlarmName** contains **Bill**:\r\n````\r\nfilteredQueueName=\"Bill\"\r\naws cloudwatch describe-alarms --query \"MetricAlarms[?contains(AlarmName, \\`${filteredQueueName}\\`) == \\`true\\`]\"\n",
      "Another example fetching alarms with **AlarmName** containing **xxx**. Rightly so, no alarms are found and empty array is returned."
    ],
    "utterance": "List all alarms whose AlarmName contains the given filteredQueueName.",
    "expressions": [
      ".MetricAlarms[] | select(.AlarmName | contains($filteredQueueName))"
    ],
    "identifier": 71621906
  },
  {
    "context": [
      "From this json output,I need to filter \"ssid\",\"bssid\",\"wlan_profile_name\",\"location\" and expected output is like below .",
      "I was trying to use jq_filter but not able to parse them in one shot",
      "```jq\n[\n   path( .. | objects | select( .ssid ) ) as $path |\n   getpath($path) |\n   { app_name: $path[-2], ssid, bssid, wlan_profile_name, location }\n]\n```"
    ],
    "utterance": "Extract all objects containing 'ssid' and output an array of objects with their containing key as 'app_name' and their 'ssid', 'bssid', 'wlan_profile_name', and 'location' fields.",
    "expressions": [
      "[ path( .. | objects | select( .ssid ) ) as $path | getpath($path) | { app_name: $path[-2], ssid, bssid, wlan_profile_name, location } ]"
    ],
    "data": [
      {
        "input": {
          "serge12": {
            "17": {
              "wlan_id": "23",
              "interface": "nwce",
              "bssid": "00:b7:71:a5:de:60",
              "atf_override": "n/a",
              "atf_policy_id": "n/a",
              "atf_policy_name": "n/a",
              "ssid": "test",
              "wlan_profile_name": "wlan",
              "location": "default location"
            },
            "18": {
              "wlan_id": "24",
              "interface": "nwcg",
              "bssid": "00:b7:71:a5:de:61",
              "atf_override": "n/a",
              "atf_policy_id": "n/a",
              "atf_policy_name": "n/a",
              "ssid": "tetra",
              "wlan_profile_name": "wnet",
              "location": "default location"
            },
            "serge13": {
              "27": {
                "wlan_id": "23",
                "interface": "nwce",
                "bssid": "00:b7:71:a5:de:58",
                "atf_override": "n/a",
                "atf_policy_id": "n/a",
                "atf_policy_name": "n/a",
                "ssid": "test",
                "wlan_profile_name": "wlan",
                "location": "default location"
              },
              "29": {
                "wlan_id": "24",
                "interface": "nwcg",
                "bssid": "00:b7:71:a5:de:69",
                "atf_override": "n/a",
                "atf_policy_id": "n/a",
                "atf_policy_name": "n/a",
                "ssid": "tetra_glance",
                "wlan_profile_name": "wnet",
                "location": "default location"
              }
            }
          }
        },
        "output": [
          {
            "app_name": "serge12",
            "bssid": "00:b7:71:a5:de:60",
            "location": "default location",
            "ssid": "test",
            "wlan_profile_name": "wlan"
          },
          {
            "app_name": "serge12",
            "bssid": "00:b7:71:a5:de:61",
            "ssid": "tetra",
            "wlan_profile_name": "wnet",
            "location": "default location"
          },
          {
            "app_name": "serge13",
            "bssid": "00:b7:71:a5:de:58",
            "location": "default location",
            "ssid": "test",
            "wlan_profile_name": "wlan"
          },
          {
            "app_name": "serge13",
            "bssid": "00:b7:71:a5:de:69",
            "ssid": "tetra_glance",
            "wlan_profile_name": "wnet",
            "location": "default location"
          }
        ]
      }
    ],
    "identifier": 71606904
  },
  {
    "context": [
      "Expected result :\r\n```\r\n{\r\n\"Test1\" :[\r\n\"abc\",\"bcd\"\r\n],\r\n\"Test2\" :[\r\n\"abc\",\"bcde\"\r\n]\r\n}\r\n```",
      "use `from_entries` to create an object from an array of key-value pairs, which can be produced by accordingly `map`ping the input object's `Objects` array.",
      ".Objects | map({key: .ElementName, value: .ElementArray}) | from_entries",
      "You can also use `reduce`",
      "reduce .Objects[] as $o ({}; .[$o.ElementName]=$o.ElementArray)"
    ],
    "utterance": "Convert an array of objects, mapping each ElementName to its ElementArray, creating an object with ElementName as keys and ElementArray as values.",
    "expressions": [
      ".Objects | map({key: .ElementName, value: .ElementArray}) | from_entries",
      "reduce .Objects[] as $o ({}; .[$o.ElementName]=$o.ElementArray)"
    ],
    "data": [
      {
        "input": {
          "Objects": [
            {
              "ElementName": "Test1",
              "ElementArray": [
                "abc",
                "bcd"
              ],
              "ElementUnit": "4"
            },
            {
              "ElementName": "Test2",
              "ElementArray": [
                "abc",
                "bcde"
              ],
              "ElementUnit": "8"
            }
          ]
        },
        "output": {
          "Test1": [
            "abc",
            "bcd"
          ],
          "Test2": [
            "abc",
            "bcde"
          ]
        }
      }
    ],
    "identifier": 71616386
  },
  {
    "context": [
      "A MongoDB employee recommends using the `EJSON.stringify` wrapper, e.g.:",
      "$ mongosh [...] --eval \"EJSON.stringify(db.adminCommand('listDatabases'))\"",
      "You can wrap your queries inside `EJSON.stringify` from inside `mongosh` console.",
      "Eg: if you want to run the query `db.books.find({\"book-id\":\"123456789\"})` execute the following.",
      "EJSON.stringify(db.books.find({\"book-id\":\"123456789\"}).toArray(), null, 2, { relaxed: false })"
    ],
    "utterance": "Obtain output for db.books.find where book-id equals 123456789 in a standard format compatible with further processing tools.",
    "expressions": [
      "EJSON.stringify(db.books.find({\"book-id\":\"123456789\"}).toArray(), null, 2, { relaxed: false })",
      "EJSON.stringify(db.adminCommand('listDatabases'))"
    ],
    "identifier": 71622473
  },
  {
    "context": [
      "I was expecting output of something like `0 1 2` but I get this error.",
      "Your example without variables works as expected. The context is being modified during the loop:",
      "$ jq -n '0 | while(.<3; .+1)'",
      "you can implement that loop using a variable like so:",
      "$ jq -n '(0,1,2) as $i | $i'",
      "Or so:",
      "$ jq -n 'range(3) as $i | $i'",
      "And here, you can employ your while loop:",
      "$ jq -n '0 | while(.<3; .+1) as $i | $i'"
    ],
    "utterance": "Produce the values 0, 1, and 2 by looping from 0 to less than 3.",
    "expressions": [
      "0 | while(.<3; .+1)",
      "(0,1,2) as $i | $i",
      "range(3) as $i | $i",
      "0 | while(.<3; .+1) as $i | $i"
    ],
    "data": [
      {
        "input": null,
        "output": [
          0,
          1,
          2
        ]
      }
    ],
    "identifier": 71626187
  },
  {
    "context": [
      "The data I receive must be transformed to build parameters for tools I use.",
      "One tool requires the following string as parameter (*it's not a json or json object - simple string*):",
      "`-parameter=\"{<IP>,[<NAME>,<ALIAS>],<COMMENT>}\"`",
      "The source data I recieve is json and looks like this",
      "I would like to transform each object array in DATASERVER to a string and push it to the key parameter.",
      "Here is my query",
      ".DATASERVER  | map((\\\"{\\\" + .NAME + \\\",[\\\"  + .IP + \\\" ,\\\"  + .ALIAS + \\\" ]}\\\") ) | {parameter: [.] }",
      "Producing the sample output from the question",
      "{parameter: .DATASERVER | map(\"{\\(.IP),[\\(.NAME),\\(.ALIAS)],staticComment}\")}",
      "{\n  \"parameter\": [\n    \"{1.1.1.2,[server02,alias02],staticComment}\",\n    \"{1.1.1.3,[server03,alias03],staticComment}\"\n  ]\n}"
    ],
    "utterance": "For each element in DATASERVER, create a string formatted as {<IP>,[<NAME>,<ALIAS>],staticComment} and collect them in a list under the key parameter.",
    "expressions": [
      "{parameter: .DATASERVER | map(\"{\\(.IP),[\\(.NAME),\\(.ALIAS)],staticComment}\")}"
    ],
    "data": [
      {
        "input": {
          "MAINSERVER": {
            "COMMENT": "Server",
            "IP": "1.1.1.1",
            "NAME": "Server1",
            "VERSION": "19.4"
          },
          "DATASERVER": [
            {
              "ALIAS": "alias02",
              "IP": "1.1.1.2",
              "NAME": "server02"
            },
            {
              "ALIAS": "alias03",
              "IP": "1.1.1.3",
              "NAME": "server03"
            }
          ]
        },
        "output": {
          "parameter": [
            "{1.1.1.2,[server02,alias02],staticComment}",
            "{1.1.1.3,[server03,alias03],staticComment}"
          ]
        }
      }
    ],
    "identifier": 71626063
  },
  {
    "context": [
      "I want to use JQ to sort each `ddd`-json-array by looking at its values in the `.fff.ggg.hhh.iii`-property.",
      "Update `|=` each field's array using `sort_by`, and convert to numbers using `tonumber`:",
      "jq '[].ddd |= sort_by(.fff.ggg.hhh.iii | tonumber)'"
    ],
    "utterance": "Sort each object's ddd array by the numerical value inside fff.ggg.hhh.iii",
    "expressions": [
      ".[].ddd |= sort_by(.fff.ggg.hhh.iii | tonumber)"
    ],
    "data": [
      {
        "input": {
          "aaa-1": {
            "ddd": [
              {
                "fff": {
                  "ggg": {
                    "hhh": {
                      "iii": "100"
                    }
                  }
                }
              },
              {
                "fff": {
                  "ggg": {
                    "hhh": {
                      "iii": "1"
                    }
                  }
                }
              },
              {
                "fff": {
                  "ggg": {
                    "hhh": {
                      "iii": "10"
                    }
                  }
                }
              }
            ]
          },
          "aaa-2": {
            "ddd": [
              {
                "fff": {
                  "ggg": {
                    "hhh": {
                      "iii": "1000"
                    }
                  }
                }
              },
              {
                "fff": {
                  "ggg": {
                    "hhh": {
                      "iii": "333"
                    }
                  }
                }
              }
            ]
          },
          "aaa-3": {
            "ddd": [
              {
                "fff": {
                  "ggg": {
                    "hhh": {
                      "iii": "77"
                    }
                  }
                }
              },
              {
                "fff": {
                  "ggg": {
                    "hhh": {
                      "iii": "88"
                    }
                  }
                }
              },
              {
                "fff": {
                  "ggg": {
                    "hhh": {
                      "iii": "5555"
                    }
                  }
                }
              },
              {
                "fff": {
                  "ggg": {
                    "hhh": {
                      "iii": "1"
                    }
                  }
                }
              }
            ]
          },
          "aaa-n": {
            "ddd": [
              {
                "fff": {
                  "ggg": {
                    "hhh": {
                      "iii": "989898"
                    }
                  }
                }
              },
              {
                "fff": {
                  "ggg": {
                    "hhh": {
                      "iii": "1"
                    }
                  }
                }
              }
            ]
          }
        },
        "output": {
          "aaa-1": {
            "ddd": [
              {
                "fff": {
                  "ggg": {
                    "hhh": {
                      "iii": "1"
                    }
                  }
                }
              },
              {
                "fff": {
                  "ggg": {
                    "hhh": {
                      "iii": "10"
                    }
                  }
                }
              },
              {
                "fff": {
                  "ggg": {
                    "hhh": {
                      "iii": "100"
                    }
                  }
                }
              }
            ]
          },
          "aaa-2": {
            "ddd": [
              {
                "fff": {
                  "ggg": {
                    "hhh": {
                      "iii": "333"
                    }
                  }
                }
              },
              {
                "fff": {
                  "ggg": {
                    "hhh": {
                      "iii": "1000"
                    }
                  }
                }
              }
            ]
          },
          "aaa-3": {
            "ddd": [
              {
                "fff": {
                  "ggg": {
                    "hhh": {
                      "iii": "1"
                    }
                  }
                }
              },
              {
                "fff": {
                  "ggg": {
                    "hhh": {
                      "iii": "77"
                    }
                  }
                }
              },
              {
                "fff": {
                  "ggg": {
                    "hhh": {
                      "iii": "88"
                    }
                  }
                }
              },
              {
                "fff": {
                  "ggg": {
                    "hhh": {
                      "iii": "5555"
                    }
                  }
                }
              }
            ]
          },
          "aaa-n": {
            "ddd": [
              {
                "fff": {
                  "ggg": {
                    "hhh": {
                      "iii": "1"
                    }
                  }
                }
              },
              {
                "fff": {
                  "ggg": {
                    "hhh": {
                      "iii": "989898"
                    }
                  }
                }
              }
            ]
          }
        }
      }
    ],
    "identifier": 71593996
  },
  {
    "context": [
      "And would like to take the first item on the first file and merge it into the second file, in order to get this output:",
      "Use `to_entries[0]` to reduce to the first item, `to_entries` to reconstruct the object, then update the `items` object using `|=`, and use `*` to merge with the second file accessed through `input`:",
      "jq '(.items |= ([to_entries[0]] | from_entries)) * input' 1.json 2.json",
      "jq '.items.foo = input.items.foo' 2.json 1.json"
    ],
    "utterance": "Add the \"foo\" field from the items of the first file into the items of the second file.",
    "expressions": [
      "jq '(.items |= ([to_entries[0]] | from_entries)) * input' 1.json 2.json",
      "jq '.items.foo = input.items.foo' 2.json 1.json"
    ],
    "data": [
      {
        "input": {
          "file1": {
            "items": {
              "foo": {
                "key": "value1"
              },
              "bar": {
                "key": "value2"
              }
            }
          },
          "file2": {
            "items": {
              "baz": {
                "key": "value3"
              },
              "qux": {
                "key": "value4"
              }
            }
          }
        },
        "output": {
          "items": {
            "baz": {
              "key": "value3"
            },
            "qux": {
              "key": "value4"
            },
            "foo": {
              "key": "value1"
            }
          }
        }
      }
    ],
    "identifier": 71648474
  },
  {
    "context": [
      "> cat A7.json | jq '.acList[] | select(.Call | contains(\"QTR\"))' - To fetch Selected airline",
      "i have to execute the command over and over again to extract the filter data which is causing to generate duplicate data.",
      "$ nc localhost 30001 | sudo jq --unbuffered '.acList[] | select (.Icao | contains(\"800CB8\"))' > A7.json",
      "The following command worked flawlessly for my problem.",
      "As you don't use the `--stream` option, I suppose your document is a *regular* JSON document.",
      "To have the output on the screen **and** also save to a file (like you did with `A7.json`), you can add a call to `tee`:"
    ],
    "utterance": "Continuously filter live data from a local server to output only aircraft where .Icao contains '800CB8', updating in real time and saving the results to a file.",
    "expressions": [
      "nc localhost 30001 | jq --unbuffered '.acList[] | select (.Icao | contains(\"800CB8\"))' > A7.json",
      "nc localhost 30001 | jq '.acList[] | select(.Call | contains(\"QTR\"))'",
      "nc localhost 30001 | tee A7.json | jq '.acList[] | select(.Icao | contains(\"800CB8\"))'",
      "while true; do sleep 1; nc 127.0.0.1 30006 | jq '.acList[] | select(.Call | contains(\"QTR\"))'; done"
    ],
    "data": [
      {
        "input": {
          "acList": [
            {
              "Icao": "800CB8",
              "Alt": 3950,
              "Call": "IAD766"
            },
            {
              "Icao": "700AAA",
              "Alt": 4200,
              "Call": "BAW123"
            }
          ]
        },
        "output": {
          "Icao": "800CB8",
          "Alt": 3950,
          "Call": "IAD766"
        }
      }
    ],
    "identifier": 71627072
  },
  {
    "context": [
      "Given an array of JSON objects, I'd like to output a CSV, but in this case i have a different keys and i need to take some values through JSONs' multiple layers.",
      "My Json file:",
      "{\r\n  \"status\": \"success\",\r\n  \"data\": {\r\n    \"n_per_page\": 10,\r\n    \"transactions_by_dealer_code\": {\r\n      \"06001\": [\r\n        {\r\n          \"dealer_name\": \"Pippo\",\r\n          \"dealer_total_transaction_count\": 0,\r\n          \"dealer_cancellation_count\": 0,\r\n          \"dealer_reservation_count\": 0,\r\n          \"transactons_detail\": []\r\n        }\r\n      ],\r\n      \"06003\": [\r\n        {\r\n          \"dealer_name\": \"Pluto\",\r\n          \"dealer_total_transaction_count\": 1,\r\n          \"dealer_cancellation_count\": 0,\r\n          \"dealer_reservation_count\": 1,\r\n          \"transactons_detail\": [\r\n            {\r\n              \"transaction_id\": \"123456789\",\r\n              \"deposite_amount\": 0.01,\r\n              \"vehicle_make\": \"ferrari\"\r\n            }\r\n          ]\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}",
      "the correct output:\n```csv transactions_by_dealer_code,dealer_name,transaction_id,deposite_amount,vehicle_make\n06001,Pippo,,,,\n06002,Pluto,123456789,0.01,ferrari\n```"
    ],
    "utterance": "For each dealer code, output its code, dealer name, and for each transaction detail (if any), the transaction ID, deposit amount, and vehicle make, as a row; if there are no transaction details, output empty values for those columns.",
    "expressions": [
      "jq -r '\n  [\"transactions_by_dealer_code\",\"dealer_name\",\"transaction_id\",\"deposite_amount\",\"vehicle_make\"],\n  (.data.transactions_by_dealer_code | to_entries[] | . as $d |\n    $d.value[] |\n    (if (.transactons_detail | length) == 0 then\n      [$d.key, .dealer_name, \"\", \"\", \"\"]\n     else\n      .transactons_detail[] | [$d.key, .dealer_name, .transaction_id, .deposite_amount, .vehicle_make]\n     end)\n  )\n  | @csv'"
    ],
    "data": [
      {
        "input": {
          "status": "success",
          "data": {
            "n_per_page": 10,
            "transactions_by_dealer_code": {
              "06001": [
                {
                  "dealer_name": "Pippo",
                  "dealer_total_transaction_count": 0,
                  "dealer_cancellation_count": 0,
                  "dealer_reservation_count": 0,
                  "transactons_detail": []
                }
              ],
              "06003": [
                {
                  "dealer_name": "Pluto",
                  "dealer_total_transaction_count": 1,
                  "dealer_cancellation_count": 0,
                  "dealer_reservation_count": 1,
                  "transactons_detail": [
                    {
                      "transaction_id": "123456789",
                      "deposite_amount": 0.01,
                      "vehicle_make": "ferrari"
                    }
                  ]
                }
              ]
            }
          }
        },
        "output": [
          "\"transactions_by_dealer_code\",\"dealer_name\",\"transaction_id\",\"deposite_amount\",\"vehicle_make\"",
          "\"06001\",\"Pippo\",\"\",\"\",\"\"",
          "\"06003\",\"Pluto\",\"123456789\",\"0.01\",\"ferrari\""
        ]
      }
    ],
    "identifier": 71619207
  },
  {
    "context": [
      "I want to compare the two one-on-one and only print the object if the corresponding boolean is `true`.",
      "So I want to output\n{\n    \"key\": \"a\",\n    \"value\": 1\n}\n{\n    \"key\": \"b\",\n    \"value\": 1\n}\n{\n    \"key\": \"e\",\n    \"value\": 1\n}",
      "jq -s '[.,[(true,true,false,false,true)]] | transpose[] | select(.[1])[0]' objects.json",
      "jq -s '.[[(true,true,false,false,true)] | indices(true)[]]' objects.json",
      "jq -n 'reduce (true,true,false,false,true) as $dict ([]; . + [input | select($dict)]) | .[]' objects.json",
      "jq -n 'foreach (true,true,false,false,true) as $dict (null; input | select($dict))' objects.json"
    ],
    "utterance": "Select only those objects from the input stream whose corresponding position in the boolean stream is true.",
    "expressions": [
      "[.,[(true,true,false,false,true)]] | transpose[] | select(.[1])[0]",
      ".[[(true,true,false,false,true)] | indices(true)[]]",
      "reduce (true,true,false,false,true) as $dict ([]; . + [input | select($dict)]) | .[]",
      "foreach (true,true,false,false,true) as $dict (null; input | select($dict))"
    ],
    "data": [
      {
        "input": [
          {
            "key": "a",
            "value": 1
          },
          {
            "key": "b",
            "value": 1
          },
          {
            "key": "c",
            "value": 1
          },
          {
            "key": "d",
            "value": 1
          },
          {
            "key": "e",
            "value": 1
          }
        ],
        "output": [
          {
            "key": "a",
            "value": 1
          },
          {
            "key": "b",
            "value": 1
          },
          {
            "key": "e",
            "value": 1
          }
        ]
      },
      {
        "input": [
          true,
          true,
          false,
          false,
          true
        ]
      }
    ],
    "identifier": 71641604
  },
  {
    "context": [
      "\u276f cat test.json | jq -L jq/script.jq 'import script;'",
      "jq: error: syntax error, unexpected IDENT, expecting FORMAT or QQSTRING_START (Unix shell quoting issues?) at <top-level>, line 1:",
      "import script;",
      "cat test.json | jq -L jq 'include \"script\"; with_entries(.value |= esprop(.))'",
      "cat test.json | jq -L jq 'import \"script\" as script; with_entries(.value |= script::esprop(.))'"
    ],
    "utterance": "Import functions from a library file located in a directory and apply the esprop function in the imported script to all .value entries using the import or include mechanism.",
    "expressions": [
      "include \"script\"; with_entries(.value |= esprop(.))",
      "import \"script\" as script; with_entries(.value |= script::esprop(.))"
    ],
    "identifier": 71660127
  },
  {
    "context": [
      "I want to extract the value of `item`:",
      "jq --stream --null-input 'fromstream(inputs | select(.[0][0] == \"item\"))[]' example.json",
      "You didn't truncate the stream, therefore after filtering it to only include the parts below `.item`, `fromstream` is missing the final back-tracking item `[[\"item\"]]`. Either add it manually at the end (not recommended, this would also include the top-level object in the result), or, much simpler, use `1 | truncate_stream` to strip the first level altogether:",
      "jq --stream --null-input '\n  fromstream(1 | truncate_stream(inputs | select(.[0][0] == \"item\")))\n' example.json",
      "Alternatively, you can use `reduce` and `setpath` to build up the result object yourself:",
      "jq --stream --null-input '\n  reduce inputs as $in (null;\n    if $in | .[0][0] == \"item\" and has(1) then setpath($in[0][1:];$in[1]) else . end\n  )\n' example.json"
    ],
    "utterance": "Extract the entire object at the top-level key 'item' from a large file using streaming mode.",
    "expressions": [
      "fromstream(1 | truncate_stream(inputs | select(.[0][0] == \"item\")))",
      "reduce inputs as $in (null; if $in | .[0][0] == \"item\" and has(1) then setpath($in[0][1:];$in[1]) else . end)"
    ],
    "data": [
      {
        "input": {
          "other": "content here",
          "item": {
            "A": {
              "B": "C"
            }
          },
          "test": "test"
        },
        "output": {
          "A": {
            "B": "C"
          }
        }
      }
    ],
    "identifier": 71661117
  },
  {
    "context": [
      "I am using an AWS CLI command with json output and it creates an array:",
      "Which returns:\n[\n    \"DEV-Lambda1-xxxx\",\n    \"DEV-Lambda2-xxxx\",\n    \"DEV-Lambda3-xxxx\",\n    \"DEV-Lambda4-xxxx\"\n]",
      "I need it to be a JSON *object*. Here is a simplified example:\n{\n\"lambda1\": \"DEV-Lambda1-xxxx\",\n\"lambda2\": \"DEV-Lambda2-xxxx\",\n\"lambda3\": \"DEV-Lambda3-xxxx\",\n\"lambda4\": \"DEV-Lambda4-xxxx\"\n}",
      "How do I transpose an array into an object?",
      "jq 'with_entries(.key |= \"lambda\\(.+1)\")'",
      "jq 'with_entries(.key = ((.value / \"-\")[1] | ascii_downcase))'",
      "jq '[ range(0; length) as $r | { ( .[$r] | split(\"-\")[1] | ascii_downcase) : .[$r] } ] | add'"
    ],
    "utterance": "Convert an array of Lambda function names into an object where each key is 'lambda' followed by the index (starting from 1), and the value is the corresponding array element.",
    "expressions": [
      "with_entries(.key |= \"lambda\\(.+1)\")",
      "with_entries(.key = ((.value / \"-\")[1] | ascii_downcase))",
      "[ range(0; length) as $r | { (\"lambda\" + ($r+1|tostring)): .[$r] } ] | add"
    ],
    "data": [
      {
        "input": [
          "DEV-Lambda1-xxxx",
          "DEV-Lambda2-xxxx",
          "DEV-Lambda3-xxxx",
          "DEV-Lambda4-xxxx"
        ],
        "output": {
          "lambda1": "DEV-Lambda1-xxxx",
          "lambda2": "DEV-Lambda2-xxxx",
          "lambda3": "DEV-Lambda3-xxxx",
          "lambda4": "DEV-Lambda4-xxxx"
        }
      }
    ],
    "identifier": 71664132
  },
  {
    "context": [
      "How can I modify that query so that I get the paths like this?",
      "`glossary.GlossDiv.GlossList.GlossEntry.GlossTerm`",
      "join the path array items using the dot as delimiter.",
      "[ paths as $path | select(getpath($path) == \"Standard Generalized Markup Language\") | $path | join(\".\") ]",
      "[ path(.. | select(strings == \"Standard Generalized Markup Language\")) | join(\".\") ]",
      "[ tostream | select(.[1] == \"Standard Generalized Markup Language\")[0] | join(\".\") ]",
      "[ \"glossary.GlossDiv.GlossList.GlossEntry.GlossTerm\" ]"
    ],
    "utterance": "Find all property paths whose value equals \"Standard Generalized Markup Language\" and output the path as a single dot-delimited string.",
    "expressions": [
      "[paths as $path | select(getpath($path) == \"Standard Generalized Markup Language\") | $path | join(\".\")]",
      "[path(.. | select(strings == \"Standard Generalized Markup Language\")) | join(\".\")]",
      "[tostream | select(.[1] == \"Standard Generalized Markup Language\")[0] | join(\".\")]"
    ],
    "data": [
      {
        "input": {
          "glossary": {
            "title": "example glossary",
            "GlossDiv": {
              "title": "S",
              "GlossList": {
                "GlossEntry": {
                  "ID": "SGML",
                  "SortAs": "SGML",
                  "GlossTerm": "Standard Generalized Markup Language",
                  "Acronym": "SGML",
                  "Abbrev": "ISO 8879:1986",
                  "GlossDef": {
                    "para": "A meta-markup language, used to create markup languages such as DocBook.",
                    "GlossSeeAlso": [
                      "GML",
                      "XML"
                    ]
                  },
                  "GlossSee": "markup"
                }
              }
            }
          }
        },
        "output": [
          "glossary.GlossDiv.GlossList.GlossEntry.GlossTerm"
        ]
      }
    ],
    "identifier": 71667732
  },
  {
    "context": [
      "I need to output in a single column the value of a field A if it's not null or the value of field B if not null or nothing if both A and B are null.",
      "jq '.fieldA // .fieldB // empty'",
      "if   .fieldA != null then .fieldA\nelif .fieldB != null then .fieldB\nelse empty\nend"
    ],
    "utterance": "Select the value of fieldA if it is not null, otherwise fieldB if it is not null, and produce no output if both are null.",
    "expressions": [
      ".fieldA // .fieldB // empty",
      "if .fieldA != null then .fieldA elif .fieldB != null then .fieldB else empty end"
    ],
    "data": [
      {
        "input": {
          "fieldA": "A1 present",
          "fieldB": "B1 present",
          "fieldC": "irrelevant"
        },
        "output": "\"A1 present\""
      },
      {
        "input": {
          "fieldB": "B2 present",
          "fieldC": "irrelevant"
        },
        "output": "\"B2 present\""
      },
      {
        "input": {
          "fieldA": "A3 present",
          "fieldC": "irrelevant"
        },
        "output": "\"A3 present\""
      },
      {
        "input": {
          "fieldC": "irrelevant"
        },
        "output": null
      }
    ],
    "identifier": 71676251
  },
  {
    "context": [
      "You can access the environment directly using `$ENV`.",
      "% export entity_name=my_entity_name",
      "% jq -r 'select(.components.schemas[$ENV.entity_name].properties != null)' file.json",
      "or simply pass the key as an explicit argument",
      "% jq -r --arg entity_name my_entity_name 'select(.components.schemas[$entity_name].properties != null)' file.json"
    ],
    "utterance": "Select input objects whose components.schemas entry named by the entity_name variable has a non-null properties field.",
    "expressions": [
      "select(.components.schemas[$ENV.entity_name].properties != null)",
      "select(.components.schemas[$entity_name].properties != null)"
    ],
    "data": [
      {
        "input": {
          "openapi": "3.0.0",
          "paths": {},
          "info": {
            "title": "My File",
            "version": "1.0.0"
          },
          "components": {
            "schemas": {
              "my_entity_name": {
                "type": "object",
                "description": "....",
                "properties": {
                  "propertyOne": {
                    "type": "string",
                    "description": "..."
                  },
                  "propertyTwo": {
                    "type": "string",
                    "format": "date",
                    "description": "..."
                  }
                }
              }
            }
          }
        },
        "output": {
          "openapi": "3.0.0",
          "paths": {},
          "info": {
            "title": "My File",
            "version": "1.0.0"
          },
          "components": {
            "schemas": {
              "my_entity_name": {
                "type": "object",
                "description": "....",
                "properties": {
                  "propertyOne": {
                    "type": "string",
                    "description": "..."
                  },
                  "propertyTwo": {
                    "type": "string",
                    "format": "date",
                    "description": "..."
                  }
                }
              }
            }
          }
        }
      }
    ],
    "identifier": 71681011
  },
  {
    "context": [
      "I'm trying to filter for items from a list that contain the values of other properties in the same object.",
      "cat data.json | jq '.result[] | select(.text | ascii_downcase | contains(.name))'",
      "jq '.result[] | select(.name as $name | .text | ascii_downcase | contains($name))'",
      "{ \"name\": \"foo\", \"text\": \"my name is foo\" }"
    ],
    "utterance": "Select objects in the result array where the text property contains the value of the name property.",
    "expressions": [
      ".result[] | select(.name as $name | .text | ascii_downcase | contains($name))"
    ],
    "data": [
      {
        "input": {
          "result": [
            {
              "name": "foo",
              "text": "my name is foo"
            },
            {
              "name": "bar",
              "text": "my name is baz"
            }
          ]
        },
        "output": {
          "name": "foo",
          "text": "my name is foo"
        }
      }
    ],
    "identifier": 71684667
  },
  {
    "context": [
      "I\u2019d to get a list of IDs for accounts that have \"externally_managed\":true.",
      "The expected result in this case is:\n```\n799dbd172f409c65\n8e09545457675ed2\n```",
      "All three of your attempts miss descending into the `.plan` object.",
      "$ jq -r '.result[] | select(.plan.externally_managed == true) | \"\\(.id)\"'",
      "$ jq -r '.result[] | select(.plan.externally_managed).id'"
    ],
    "utterance": "Get a list of account ids where the account's plan is externally managed (externally_managed is true).",
    "expressions": [
      ".result[] | select(.plan.externally_managed == true) | .id",
      ".result[] | select(.plan.externally_managed) | .id"
    ],
    "data": [
      {
        "input": {
          "result": [
            {
              "id": "799dbd172f409c65",
              "status": "active",
              "plan": {
                "planid": "0feeeeeeeeeeeeeeee",
                "name": "Enterprise",
                "externally_managed": true
              }
            },
            {
              "id": "a00eb4acb5905100",
              "status": "active",
              "plan": {
                "planid": "0feeeeeeeeeeeeeeee",
                "name": "Enterprise",
                "externally_managed": false
              }
            },
            {
              "id": "8e09545457675ed2",
              "status": "active",
              "plan": {
                "planid": "0feeeeeeeeeeeeeeee",
                "name": "Enterprise",
                "externally_managed": true
              }
            }
          ]
        },
        "output": [
          "799dbd172f409c65",
          "8e09545457675ed2"
        ]
      }
    ],
    "identifier": 71684162
  },
  {
    "context": [
      "What would be the best way to convert the id value from an int to a string and then saving the file?",
      "The solution is to use parentheses to enforce the desired order of execution.\nThe command is:\n\n```\njq '[ .[] | .id = (.id | tostring) ]' test.json\n```"
    ],
    "utterance": "Convert the id field value from number to string in each object of the array.",
    "expressions": [
      "[ .[] | .id = (.id | tostring) ]"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "firstName": "firstName1",
            "lastName": "lastName1"
          },
          {
            "id": 2,
            "firstName": "firstName2",
            "lastName": "lastName2"
          },
          {
            "id": 3,
            "firstName": "firstName3",
            "lastName": "lastName3"
          }
        ],
        "output": [
          {
            "id": "1",
            "firstName": "firstName1",
            "lastName": "lastName1"
          },
          {
            "id": "2",
            "firstName": "firstName2",
            "lastName": "lastName2"
          },
          {
            "id": "3",
            "firstName": "firstName3",
            "lastName": "lastName3"
          }
        ]
      }
    ],
    "identifier": 71682906
  },
  {
    "context": [
      "If I use this:\r\n\r\n    echo \"$(&<file_1.json)\" | jq -r '[\"ID\",\"NAME\"], [\"--\",\"------\"], (.users[] | .userId, .lastName)'\r\n\r\nI get this:\r\n\r\n    [\r\n      \"ID\",\r\n      \"NAME\"\r\n    ]\r\n    [\r\n      \"--\",\r\n      \"------\"\r\n    ]\r\n    1\r\n    lastName_1\r\n    2\r\n    lastName_2\r\n    3\r\n    lastName_3\r\n    4\r\n    lastName_4\r\n    5\r\n    lastName_5",
      "If I try this:\r\n\r\n    echo \"$(&<file_1.json)\" | jq -r '[\"ID\",\"NAME\"], [\"--\",\"------\"], (.users[] | .userId, .lastName) | @tsv'\r\n\r\nI get this:\r\n\r\n    ID      NAME\r\n    --      ------\r\n    assertion \"cb == jq_util_input_next_input_cb\" failed: file \"/usr/src/ports/jq/jq-1.6-1.x86_64/src/jq-1.6/src/util.c\", line 371, function: jq_util_input_get_position",
      "You were missing the array brackets around `.userId, .lastName` (which are also present in the solution you have linked to).\r\n~~~none\r\n[\"ID\",\"NAME\"], [\"--\",\"------\"], (.users[] | [.userId, .lastName]) | @tsv\r\n~~~",
      "ID\tNAME\r\n--\t------\r\n1\tlastName_1\r\n2\tlastName_2\r\n3\tlastName_3\r\n4\tlastName_4\r\n5\tlastName_5"
    ],
    "utterance": "Produce a tab-separated table with header rows ID and NAME, a separator row, and columns for userId and lastName from all users",
    "expressions": [
      "[\"ID\",\"NAME\"], [\"--\",\"------\"], (.users[] | [.userId, .lastName]) | @tsv"
    ],
    "data": [
      {
        "input": {
          "users": [
            {
              "userId": 1,
              "firstName": "firstName_1",
              "lastName": "lastName_1",
              "phoneNumber": "111111111",
              "emailAddress": "emailAddress_1@email.com"
            },
            {
              "userId": 2,
              "firstName": "firstName_2",
              "lastName": "lastName_2",
              "phoneNumber": "222222222",
              "emailAddress": "emailAddress_2@email.com"
            },
            {
              "userId": 3,
              "firstName": "firstName_3",
              "lastName": "lastName_3",
              "phoneNumber": "333333333",
              "emailAddress": "emailAddress_3@email.com"
            },
            {
              "userId": 4,
              "firstName": "firstName_4",
              "lastName": "lastName_4",
              "phoneNumber": "444444444",
              "emailAddress": "emailAddress_4@email.com"
            },
            {
              "userId": 5,
              "firstName": "firstName_5",
              "lastName": "lastName_5",
              "phoneNumber": "555555555",
              "emailAddress": "emailAddress_5@email.com"
            }
          ]
        },
        "output": "ID\tNAME\n--\t------\n1\tlastName_1\n2\tlastName_2\n3\tlastName_3\n4\tlastName_4\n5\tlastName_5"
      }
    ],
    "identifier": 71662276
  },
  {
    "context": [
      "I want to obtain this output:\r\n\r\n    { \"core\",\"ITEM1\" }\r\n    { \"core\",\"ITEM2\" }\r\n    { \"misc\",\"ITEM3\" } \r\n    { \"misc\",\"ITEM4\" }\r\n    { \"misc\",\"ITEM5\" }",
      "To only capture words that match the regex `ITEM\\d+`, you could employ the `scan` function instead of splitting:\r\n~~~sh\r\njq '.parts[] | {(.name): .items | scan(\"ITEM\\\\d+\")}'\r\n~~~",
      "This produces a stream of objects such as '{\"core\":\"ITEM1\"}'."
    ],
    "utterance": "Extract each ITEM followed by a number from the items value and pair it with its parent name.",
    "expressions": [
      ".parts[] | {(.name): .items | scan(\"ITEM\\\\d+\")}",
      ".parts | .[] | .items |= (split(\" \") | map(select(test(\"ITEM\")))) | {(.name): .items[]}"
    ],
    "data": [
      {
        "input": {
          "parts": [
            {
              "name": "core",
              "items": "garbage with ITEM1 ITEM2 and more"
            },
            {
              "name": "misc",
              "items": "ITEM3 ITEM4 ITEM5 bla bla"
            }
          ]
        },
        "output": [
          {
            "core": "ITEM1"
          },
          {
            "core": "ITEM2"
          },
          {
            "misc": "ITEM3"
          },
          {
            "misc": "ITEM4"
          },
          {
            "misc": "ITEM5"
          }
        ]
      }
    ],
    "identifier": 71699864
  },
  {
    "context": [
      "Or Is there any way to sort the JsonFile 1 by attribute \"name\" is ascending order ( Expected output- JsonFile2)",
      "You can sort the array located at `.data.type_fields` by its  object items' field `.name` using `sort_by` and the update operator `|=`.",
      "jq '.data.type_fields |= sort_by(.name)' JsonFile1 > JsonFile2"
    ],
    "utterance": "Sort the array under the 'type_fields' property within the 'data' object by each item's 'name' field in ascending order.",
    "expressions": [
      ".data.type_fields |= sort_by(.name)"
    ],
    "data": [
      {
        "input": {
          "responseStatus": "SUCCESS",
          "data": {
            "name": "reusable_text__v",
            "object": "annotation_keywords__sys",
            "label": "Reusable Text",
            "label_plural": "Reusable Text",
            "active": true,
            "additional_type_validations": [],
            "type_fields": [
              {
                "required": true,
                "source": "standard",
                "name": "reusable_text_content__v"
              },
              {
                "required": false,
                "source": "standard",
                "name": "reusable_text_type__v"
              },
              {
                "required": false,
                "source": "standard",
                "name": "source_text_asset__v"
              },
              {
                "required": false,
                "source": "standard",
                "name": "country__v"
              },
              {
                "required": false,
                "source": "standard",
                "name": "create_from_annotation_id__sys"
              },
              {
                "required": false,
                "source": "standard",
                "name": "create_from_annotation_source__sys"
              },
              {
                "required": false,
                "source": "standard",
                "name": "product__v"
              },
              {
                "required": false,
                "source": "standard",
                "name": "id"
              },
              {
                "required": true,
                "source": "standard",
                "name": "name__v"
              },
              {
                "required": true,
                "source": "standard",
                "name": "status__v"
              },
              {
                "required": false,
                "source": "standard",
                "name": "created_by__v"
              },
              {
                "required": false,
                "source": "standard",
                "name": "created_date__v"
              },
              {
                "required": false,
                "source": "standard",
                "name": "modified_by__v"
              },
              {
                "required": false,
                "source": "standard",
                "name": "modified_date__v"
              },
              {
                "required": false,
                "source": "system",
                "name": "global_id__sys"
              },
              {
                "required": false,
                "source": "system",
                "name": "link__sys"
              },
              {
                "required": false,
                "source": "standard",
                "name": "object_type__v"
              },
              {
                "required": true,
                "source": "custom",
                "name": "lifecycle__v"
              },
              {
                "required": true,
                "source": "custom",
                "name": "state__v"
              },
              {
                "required": false,
                "source": "custom",
                "name": "create_from_annotation_source_unbound__sys"
              },
              {
                "required": false,
                "source": "system",
                "name": "state_stage_id__sys"
              },
              {
                "required": false,
                "source": "system",
                "name": "stage__sys"
              }
            ]
          }
        }
      }
    ],
    "identifier": 71608432
  },
  {
    "context": [
      "I have a JSON in the shape\n\n    [\n      {\n        a:1,\n        b: [2,3]\n      },\n      {\n        a:4,\n        b: [5,6]\n      }\n    ]\n\nThat I want to transform in the shape\n\n    [\n      [\n        {\n          a: 1,\n          b: 2,\n        },\n        {\n          a: 1,\n          b: 3,\n        },\n      ],\n      [\n        {\n          a: 4,\n          b: 5,\n        },\n        {\n          a: 4,\n          b: 6,\n        },\n      ],\n    ]\n    \n\nThat is I want to bring the value of the field `a` inside the array.",
      "jq 'map(.a as $a | [.b[] as $b | {$a,$b}])'",
      "jq 'map([.b[] as $b | .b |= $b])'",
      "jq 'map([{a,b:.b[]}])'",
      "jq 'map([.b=.b[]])'"
    ],
    "utterance": "For each object with fields a and b (where b is an array), produce a list of objects where each contains the original a and one element of b as b, grouping these lists per input object.",
    "expressions": [
      "map(.a as $a | [.b[] as $b | {a: $a, b: $b}])",
      "map([.b[] as $b | {a: .a, b: $b}])",
      "map([.b[] as $b | .b |= $b])",
      "map([{a, b:.b[]}])",
      "map([.b=.b[]])"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1,
            "b": [
              2,
              3
            ]
          },
          {
            "a": 4,
            "b": [
              5,
              6
            ]
          }
        ],
        "output": [
          [
            {
              "a": 1,
              "b": 2
            },
            {
              "a": 1,
              "b": 3
            }
          ],
          [
            {
              "a": 4,
              "b": 5
            },
            {
              "a": 4,
              "b": 6
            }
          ]
        ]
      }
    ],
    "identifier": 71708143
  },
  {
    "context": [
      "I am trying to grab the variable names and the values, using jq. I want output that links the two together in any form of structured data. Something that would look/function similar to:",
      "varible1,value1",
      "varible2,value2",
      "varible3,value3",
      "varible4,value4",
      "Using `to_entries`:",
      "jq -r '.variables | to_entries[] | [ .key, .value.value ] | @csv'",
      "Using `keys`:",
      "jq -r '.variables | keys[] as $k | [ $k, .[$k].value ] | @csv'"
    ],
    "utterance": "List each variable key under 'variables' with its corresponding 'value', formatted as CSV lines.",
    "expressions": [
      ".variables | to_entries[] | [ .key, .value.value ] | @csv",
      ".variables | keys[] as $k | [ $k, .[$k].value ] | @csv"
    ],
    "data": [
      {
        "input": {
          "Object0": {
            "data01": "value01",
            "data02": "value02",
            "data03": "value03",
            "data04": "value04"
          },
          "Object1": {
            "data11": "value11",
            "data12": "value12",
            "data13": "value13",
            "data14": "value14"
          },
          "variables": {
            "variable1": {
              "isSecret": null,
              "value": "value1"
            },
            "variable2": {
              "isSecret": null,
              "value": "value2"
            },
            "variable3": {
              "isSecret": null,
              "value": "value3"
            },
            "variable4": {
              "isSecret": null,
              "value": "value4"
            }
          }
        },
        "output": [
          "\"variable1\",\"value1\"",
          "\"variable2\",\"value2\"",
          "\"variable3\",\"value3\"",
          "\"variable4\",\"value4\""
        ]
      }
    ],
    "identifier": 71721556
  },
  {
    "context": [
      "my question is: is there is a way to select field out of possible fields in `jq` ?",
      "tried to fix it by `.[] | {ARTIFACTID, ARTIFACT_ID}` but can't understand how to leave only the valid values",
      "Use a `select` expression with a boolean condition",
      ".Components | map(select(.ARTIFACTID or .ARTIFACT_ID))"
    ],
    "utterance": "Select all objects in Components that have either ARTIFACTID or ARTIFACT_ID present.",
    "expressions": [
      ".Components | map(select(.ARTIFACTID or .ARTIFACT_ID))"
    ],
    "data": [
      {
        "input": {
          "Components": [
            {
              "ARTIFACTID": "good artifact",
              "BuildJobDate": "2020-01-20T16:39:50"
            },
            {
              "ARTIFACT_ID": "bad artifact",
              "BuildJobDate": "'2021-11-29T17:23:39'"
            },
            {
              "ARTIFACTID": "another good artifact",
              "BuildJobDate": "2022-01-26T21:18:20"
            }
          ]
        },
        "output": [
          {
            "ARTIFACTID": "good artifact",
            "BuildJobDate": "2020-01-20T16:39:50"
          },
          {
            "ARTIFACT_ID": "bad artifact",
            "BuildJobDate": "'2021-11-29T17:23:39'"
          },
          {
            "ARTIFACTID": "another good artifact",
            "BuildJobDate": "2022-01-26T21:18:20"
          }
        ]
      }
    ],
    "identifier": 71740097
  },
  {
    "context": [
      "I have a json stream that I want to make the output into single line with jq ( Linux )",
      "From this\n{\n  \"Icao\": \"800B0A\",\n  \"Alt\": 15375,\n  ...\n}\n{\n  \"Icao\": \"800463\",\n  \"Alt\": 3575,\n  ...\n}",
      "To this\n{\"Icao\":\"A379CD\",\"Alt\":32025,...},{\"Icao\":\"345042\",\"Alt\":22850,...},{\"Icao\":\"40753D\",\"Alt\":37000,...},",
      "The `--compact-output` (or `-c`) option qill print each object in a single line, and the `--join-output` (or `-j`) option will omit the newline character between the objects.",
      "jq -cj .",
      "Note that while this is valid JSON, your desired output is not. It has commas after the objects. If you really need them, you can print a literal string like a comma using the `--raw-output` (or `-r`) option:",
      "jq -cjr '.,\",\"'"
    ],
    "utterance": "Print each object from a stream as a single line, joined together with commas at the end of each object.",
    "expressions": [
      "jq -cj .",
      "jq -cjr '.,\",\"'"
    ],
    "data": [
      {
        "input": [
          {
            "Icao": "800B0A",
            "Alt": 15375,
            "GAlt": 15278,
            "AltT": 0,
            "Lat": 10.579605,
            "Long": 76.506561,
            "Mlat": false,
            "Spd": 334.5,
            "Trak": 26.3,
            "Vsi": 832
          },
          {
            "Icao": "800463",
            "Alt": 3575,
            "GAlt": 3445,
            "AltT": 0,
            "Lat": 40.626663,
            "Long": -74.261963,
            "Mlat": false,
            "Spd": 274.4,
            "Trak": 316.2,
            "Vsi": 1472
          }
        ],
        "output": "{\"Icao\":\"800B0A\",\"Alt\":15375,\"GAlt\":15278,\"AltT\":0,\"Lat\":10.579605,\"Long\":76.506561,\"Mlat\":false,\"Spd\":334.5,\"Trak\":26.3,\"Vsi\":832},{\"Icao\":\"800463\",\"Alt\":3575,\"GAlt\":3445,\"AltT\":0,\"Lat\":40.626663,\"Long\":-74.261963,\"Mlat\":false,\"Spd\":274.4,\"Trak\":316.2,\"Vsi\":1472},"
      }
    ],
    "identifier": 71728099
  },
  {
    "context": [
      "I want to work on the bucket element that has the key \"this.com\". Matching works, but I still get both sub elements.",
      "but I would like to access only monthly.buckets of the matching one.",
      "jq '.aggregations.sites_monthly_top_10.buckets[] | select(.key == \"this.com\").monthly.buckets' response.json",
      "[\n  {\n    \"key_as_string\": \"2021-03 March\",\n    \"key\": 1614556800000,\n    \"doc_count\": 16733\n  },\n  {\n    \"key_as_string\": \"2021-04 April\",\n    \"key\": 1617235200000,\n    \"doc_count\": 12744\n  }\n]"
    ],
    "utterance": "Get the monthly.buckets array for the bucket whose key is exactly \"this.com\" in sites_monthly_top_10",
    "expressions": [
      ".aggregations.sites_monthly_top_10.buckets[] | select(.key == \"this.com\").monthly.buckets"
    ],
    "data": [
      {
        "input": {
          "took": 189,
          "timed_out": false,
          "_shards": {
            "total": 5,
            "successful": 5,
            "skipped": 0,
            "failed": 0
          },
          "hits": {
            "total": 614388,
            "max_score": 0,
            "hits": []
          },
          "aggregations": {
            "sites_monthly_top_10": {
              "doc_count_error_upper_bound": 4507,
              "sum_other_doc_count": 205762,
              "buckets": [
                {
                  "key": "this.com",
                  "doc_count": 120903,
                  "monthly": {
                    "buckets": [
                      {
                        "key_as_string": "2021-03 March",
                        "key": 1614556800000,
                        "doc_count": 16733
                      },
                      {
                        "key_as_string": "2021-04 April",
                        "key": 1617235200000,
                        "doc_count": 12744
                      }
                    ]
                  }
                },
                {
                  "key": "that.com",
                  "doc_count": 81451,
                  "monthly": {
                    "buckets": [
                      {
                        "key_as_string": "2021-03 March",
                        "key": 1614556800000,
                        "doc_count": 4641
                      },
                      {
                        "key_as_string": "2021-04 April",
                        "key": 1617235200000,
                        "doc_count": 8687
                      }
                    ]
                  }
                }
              ]
            }
          }
        },
        "output": [
          {
            "key_as_string": "2021-03 March",
            "key": 1614556800000,
            "doc_count": 16733
          },
          {
            "key_as_string": "2021-04 April",
            "key": 1617235200000,
            "doc_count": 12744
          }
        ]
      }
    ],
    "identifier": 71732014
  },
  {
    "context": [
      "jq '.xJSON.statusCode' jsontest",
      "jq: error (at jsontest:1): Cannot index string with string \"statusCode\"",
      "I cannot get any data from it using jq, i keep getting nulls or \"Cannot index string with string \"statusCode\""
    ],
    "utterance": "Extract the appId value from within the nested, stringified objects inside the xJSON and pJSON fields where appId is \"com.rrrr.test\".",
    "expressions": [
      ".xJSON | fromjson | .pJSON | fromjson | .body.appConfiguration.appId"
    ],
    "data": [
      {
        "input": {
          "xJSON": "{\"statusCode\":\"200\", \"status\": \"OK\",\"pJSON\": \"{\\\"body\\\": {\\\"assets\\\": {\\\"loadingBackgroundImageBase64\\\": \\\"iVBII=\\\",\\\"loginBackgroundImageBase64\\\": \\\"iVBORwTkSuQmCC\\\",\\\"splashImageBase64\\\": \\\"iVBORw0KGgAAAAElFTkSuQmCC\\\",\\\"iconImageBase64\\\": \\\"iVBORw0KGgoAAAA6ZH+gAAAABJRU5ErkJggg==\\\"},\\\"build-configuration\\\": {\\\"token\\\": \\\"dwqsdadsa\\\",\\\"storePassword\\\": \\\"3332sa\\\",\\\"googleServicesAndroidBase64\\\": \\\"ewogICIxIgp9\\\",\\\"keystore\\\": \\\"/u3+7Iy4IJYPYxbg==\\\",\\\"keystore-password\\\": \\\"33332d\\\",\\\"keystore-alias\\\": \\\"consist\\\",\\\"googleServicesIOSBase64\\\": \\\"PD94bWc3Q+\\\"},\\\"appConfiguration\\\": {\\\"id\\\": \\\"94c2c3063ee3fbc3847ce6\\\",\\\"appVersion\\\": \\\"7.9.0\\\",\\\"buildVersion\\\": \\\"1.0.0.0.0\\\",\\\"responseContext\\\": \\\"pruebareportes\\\",\\\"soVersion\\\": \\\"android\\\",\\\"initialContext\\\": {\\\"name\\\": \\\"pruebareportes\\\",\\\"url\\\": \\\"pruebareportes.test.com\\\"},\\\"appName\\\": \\\"test\\\",\\\"appId\\\": \\\"com.rrrr.test\\\",\\\"tabs\\\": [{\\\"iconName\\\": \\\"icon_app-home\\\",\\\"configuration\\\": {\\\"item1\\\": \\\"prueba\\\"},\\\"title\\\": \\\"Inicio\\\",\\\"type\\\": \\\"home\\\"}]}}}\"}"
        },
        "output": "com.rrrr.test"
      }
    ],
    "identifier": 71745498
  },
  {
    "context": [
      "color_values=$(cat $figma_json | jq -r '.color')",
      "for c_key in $color_keys\r\ndo\r\n\r\n    echo \"key string: $c_key\"\r\n\r\n    echo $color_values | jq \".$c_key.value\";\r\n    echo \"*********************************************\";\r\ndone",
      "jq -r '.color | to_entries[] | \"\\(.key): \\(.value.value)\"' \"$figma_json\"",
      "Output\n\ngray1: #333333ff\ngray2: #4f4f4fff\ngray3: #828282ff\ngray4: #bdbdbdff\ngray5: #e0e0e0ff\ngray6: #f2f2f2ff\nred: #eb5757ff\norange: #f2994aff\nyellow: #f2c94cff\ngreen1: #219653ff\ngreen2: #27ae60ff\ngreen3: #6fcf97ff\nblue1: #2f80edff\nblue2: #2d9cdbff\nblue3: #56ccf2ff\npurple1: #9b51e0ff\npurple2: #bb6bd9ff"
    ],
    "utterance": "List all color keys and their corresponding hex values as key: value pairs from the color object.",
    "expressions": [
      ".color | to_entries[] | \"\u001b[38;2;255;255;255m\\(.key): \\(.value.value)\"",
      ".color | to_entries[] | \"\\(.key): \\(.value.value)\""
    ],
    "identifier": 71750689
  },
  {
    "context": [
      "I have JSON name values that look like this",
      "{\r\n  \"key1\": true,\r\n  \"key2\": \"1.9.2\",\r\n  \"key3\": \"value3\"\r\n}",
      "how can I loop over it using bash  and jq so the output will look like this:",
      "export key1=true",
      "export key2=\"1.9.2\"",
      "export key3=\"value3\""
    ],
    "utterance": "Print all key-value pairs so that each line is formatted as export key=value, quoting string values",
    "expressions": [
      "to_entries[] | \"export \\(.key)=\\(if (.value|type)==\\\"string\\\" then \\\"\\\"\\\"\\(.value)\\\"\\\"\\\" else (.value|tostring) end)\""
    ],
    "data": [
      {
        "input": {
          "key1": true,
          "key2": "1.9.2",
          "key3": "value3"
        },
        "output": [
          "export key1=true",
          "export key2=\"1.9.2\"",
          "export key3=\"value3\""
        ]
      }
    ],
    "identifier": 71767039
  },
  {
    "context": [
      "How can I get the value of \"Duration\" in a variable for further use?",
      "That would be\n\nyour_json_file.media.track[0].Duration",
      "To get to **FrameCount** in the JSON content, the solution for me is:\n\n    jq.exe -r .media.track[0].FrameCount C:\\MP4convert\\test\\%filenam%.json > test1.txt\n    for /f \"delims=\" %%x in (test1.txt) do set FrCountVar=%%x\n\nFor future use, I put the count in a new variable:\n\n    SET FrCount=%FrCountVar%"
    ],
    "utterance": "Retrieve the value of Duration from the first element of the media.track array.",
    "expressions": [
      ".media.track[0].Duration"
    ],
    "data": [
      {
        "input": {
          "creatingLibrary": {
            "name": "MediaInfoLib",
            "version": "21.09",
            "url": "https://mediaarea.net/MediaInfo"
          },
          "media": {
            "@ref": "J:\\Austria\\Tag5\\EOS_ben\\100EOS5D\\TW_6248.MOV",
            "track": [
              {
                "@type": "General",
                "VideoCount": "1",
                "AudioCount": "1",
                "OtherCount": "1",
                "FileExtension": "MOV",
                "Format": "MPEG-4",
                "Format_Profile": "QuickTime",
                "CodecID": "qt  ",
                "CodecID_Version": "2007.09",
                "CodecID_Compatible": "qt  /CAEP",
                "FileSize": "37229924",
                "Duration": "9.520",
                "OverallBitRate_Mode": "VBR",
                "OverallBitRate": "31285650",
                "FrameRate": "25.000",
                "FrameCount": "238",
                "StreamSize": "100484",
                "HeaderSize": "98304",
                "DataSize": "37130652",
                "FooterSize": "968",
                "IsStreamable": "Yes",
                "Encoded_Date": "UTC 2014-03-13 22:31:17",
                "Tagged_Date": "UTC 2014-03-13 22:31:17",
                "File_Created_Date": "UTC 2014-03-13 21:31:26.000",
                "File_Created_Date_Local": "2014-03-13 23:31:26.000",
                "File_Modified_Date": "UTC 2014-03-13 21:31:26.000",
                "File_Modified_Date_Local": "2014-03-13 23:31:26.000",
                "Copyright": "BEN PAYA",
                "extra": {
                  "com_apple_quicktime_make": "Canon",
                  "com_apple_quicktime_model": "Canon EOS 5D Mark III",
                  "com_apple_quicktime_rating_user": "0.000",
                  "com_apple_quicktime_author": "PhilFried"
                }
              },
              {
                "@type": "Video",
                "StreamOrder": "0",
                "ID": "1"
              }
            ]
          }
        },
        "output": "9.520"
      }
    ],
    "identifier": 71716898
  },
  {
    "context": [
      "What I need is a way to access both key name and the value of 'value' in the same loop.",
      "jq -r '.variables | keys_unsorted[] as $k | \"\\($k) \\(.[$k].value)\"'",
      "jq -r '.variables | to_entries[] | \"\\(.key): \\(.value.value)\"'",
      "jq '.variables | with_entries(.value |= .value)'"
    ],
    "utterance": "List each key in 'variables' alongside its associated 'value' field.",
    "expressions": [
      ".variables | keys_unsorted[] as $k | \"\u0000($k) \u0000(.[$k].value)\"",
      ".variables | to_entries[] | \"\u0000(.key): \u0000(.value.value)\"",
      ".variables | with_entries(.value |= .value)"
    ],
    "data": [
      {
        "input": {
          "id": 5,
          "variables": {
            "variable1": {
              "isSecret": null,
              "value": "value1"
            },
            "variable2": {
              "isSecret": null,
              "value": "value2"
            }
          }
        },
        "output": [
          "variable1 value1",
          "variable2 value2"
        ]
      },
      {
        "input": {
          "id": 5,
          "variables": {
            "variable1": {
              "isSecret": null,
              "value": "value1"
            },
            "variable2": {
              "isSecret": null,
              "value": "value2"
            }
          }
        },
        "output": {
          "variable1": "value1",
          "variable2": "value2"
        }
      }
    ],
    "identifier": 71751805
  },
  {
    "context": [
      "Actual output:\n\n```none\nwhite:#ffffffff gray:#fafafaff \n```",
      "Excepted output:\n\n```none\nwhite:#ffffffff gray:50:#fafafaff\n```",
      "Here's a solution using `tostream` instead of `to_entries` to facilitate simultaneous access to the full path and its value:\n~~~sh\njq -r '\n  .color | tostream | select(.[0][-1] == \"value\" and has(1)) | .[0][:-1]+.[1:] | join(\":\")\n' \"$figma_json\"\n~~~",
      "jq -r '\n  def recurse_for_value($prefix):\n    to_entries[]\n    | .key as $current_key\n    | .value?.value? as $immediate_value\n    | if $immediate_value == null then\n        .value | recurse_for_value(\n                   if $prefix != \"\" then\n                     $prefix + \":\" + $current_key\n                   else\n                     $current_key\n                   end\n                 )\n      else\n        if $prefix == \"\" then\n          \"\\($current_key):\\($immediate_value)\"\n        else\n          \"\\($prefix):\\($current_key):\\($immediate_value)\"\n        end\n      end\n    ;\n  .color |\n  recurse_for_value(\"\")\n' \"$figma_json\"\n"
    ],
    "utterance": "List all color names and nested subkeys with their corresponding value fields, separated by colons, so that nested keys appear as e.g. gray:50:#fafafaff.",
    "expressions": [
      ".color | tostream | select(.[0][-1] == \"value\" and has(1)) | .[0][:-1]+.[1:] | join(\":\")",
      "def recurse_for_value($prefix):\n  to_entries[]\n  | .key as $current_key\n  | .value?.value? as $immediate_value\n  | if $immediate_value == null then\n      .value | recurse_for_value(\n                 if $prefix != \"\" then\n                   $prefix + \":\" + $current_key\n                 else\n                   $current_key\n                 end\n               )\n    else\n      if $prefix == \"\" then\n        \"\\($current_key):\\($immediate_value)\"\n      else\n        \"\\($prefix):\\($current_key):\\($immediate_value)\"\n      end\n    end\n  ;\n.color |\nrecurse_for_value(\"\")"
    ],
    "data": [
      {
        "input": {
          "color": {
            "white": {
              "description": "this is just plain white color",
              "type": "color",
              "value": "#ffffffff",
              "extensions": {
                "org.lukasoppermann.figmaDesignTokens": {
                  "styleId": "S:40940df38088633aa746892469dd674de8b147eb,",
                  "exportKey": "color"
                }
              }
            },
            "gray": {
              "50": {
                "description": "",
                "type": "color",
                "value": "#fafafaff",
                "extensions": {
                  "org.lukasoppermann.figmaDesignTokens": {
                    "styleId": "S:748a0078c39ca645fbcb4b2a5585e5b0d84e5fd7,",
                    "exportKey": "color"
                  }
                }
              }
            }
          }
        },
        "output": [
          "white:#ffffffff",
          "gray:50:#fafafaff"
        ]
      }
    ],
    "identifier": 71772406
  },
  {
    "context": [
      "The desired output is to capture this:\r\n\r\n.lastAccessStr\r\n.elapsedTimeMs\r\n.clientName (if available in output)\r\n.requestID (if available in output)\r\n.agentAddr (if available in output)\r\n.localAddr (if available in output)",
      "User [pmf](https://stackoverflow.com/users/2158479/pmf) has got it [in the comments](https://stackoverflow.com/questions/71711506/how-do-i-use-jq-to-convert-nested-json-output-to-csv#comment126734655_71711506):\r\n\r\n> Use `?` to ignore an error, and `//` to provide an alternative if the first one is `null`, `false` or inexistent. Define every column at question along the lines of `(.clientConnInfo.clientName? // \"none\")`"
    ],
    "utterance": "Extract lastAccessStr, elapsedTimeMs, clientName (if present), requestID (if present), agentAddr (if present), and localAddr (if present) as CSV columns from each session record, returning a default value when missing.",
    "expressions": [
      ".result.Session[] | [ .lastAccessStr, .elapsedTimeMs, (.clientConnInfo.clientName? // \"none\"), (.clientConnInfo.requestID? // \"none\"), (.agentConnInfo.agentAddr? // \"none\"), (.agentConnInfo.localAddr? // \"none\") ] | @csv"
    ],
    "data": [
      {
        "input": {
          "operation": "GET CLIENT SESSIONS",
          "outcome": "SUCCESS",
          "result": {
            "Session": [
              {
                "sessionID": "E1B7190EF32AA9F6E63265ADBB88D1A9D6F4254457A0.production",
                "requestID": "",
                "sessionPoolID": "8LNIVzRTSo-jJV-CdPMP0Q",
                "agentID": "",
                "ablSessionID": "",
                "lastAccessStr": "2022-04-01T10:36:14.745-0700",
                "elapsedTimeMs": 1675892,
                "sessionState": "AVAILABLE",
                "requestState": "READY",
                "sessionType": "SESSION_FREE",
                "adapterType": "APSV",
                "bound": false,
                "clientConnInfo": null,
                "agentConnInfo": null
              },
              {
                "sessionID": "26691913A73E55175D233F86D219B4AEFA4AD14AE9E4.production",
                "requestID": "ROOT:a:000002a6",
                "sessionPoolID": "8LNIVzRTSo-jJV-CdPMP0Q",
                "agentID": "qsrLXAxsRRanJio6dYOC2Q",
                "ablSessionID": "",
                "lastAccessStr": "2022-04-01T11:04:08.902-0700",
                "elapsedTimeMs": 1735,
                "sessionState": "RESERVED",
                "requestState": "RUNNING",
                "sessionType": "SESSION_FREE",
                "adapterType": "APSV",
                "bound": false,
                "clientConnInfo": {
                  "clientName": "xxxxx",
                  "requestID": "ROOT:a:000002a6",
                  "sessionID": "26691913A73E55175D233F86D219B4AEFA4AD14AE9E4.production",
                  "adapterType": "APSV",
                  "reqStartTimeStr": "2022-04-01T11:04:08.902-0700",
                  "elapsedTimeMs": 1735,
                  "executerThreadId": "thd-8",
                  "requestUrl": "xxxxx",
                  "requestProcedure": "xxxxx.p",
                  "httpSessionId": "26691913A73E55175D233F86D219B4AEFA4AD14AE9E4.production"
                },
                "agentConnInfo": {
                  "agentID": "qsrLXAxsRRanJio6dYOC2Q",
                  "connID": "AR2k7gnYSiKPCk2DEHpaSg",
                  "connPoolID": "v0Lh7XcITsOSfoF_RjXXig",
                  "state": "RESERVED",
                  "agentAddr": "xxxxx",
                  "localAddr": "xxxxx"
                }
              }
            ]
          },
          "errmsg": "",
          "versionStr": "v1.0.0 ( 2021-10-29 )",
          "versionNo": 1
        },
        "output": [
          "\"2022-04-01T10:36:14.745-0700\",1675892,\"none\",\"none\",\"none\",\"none\"",
          "\"2022-04-01T11:04:08.902-0700\",1735,\"xxxxx\",\"ROOT:a:000002a6\",\"xxxxx\",\"xxxxx\""
        ]
      }
    ],
    "identifier": 71711506
  },
  {
    "context": [
      "in the to_file, inside each object that contains \"columnId\": 5206337428711300 I need to add all the key value pairs (except for \"Column\" and \"columnId\") from the from_file \"columnId\": 5822630258337668 containing object where that array of cell's \"columnId\": 7408953102493572 containing object has the same \"displayValue\" value as the to_file's \"columnId\": 5460306864433028 containing objects \"displayValue\" value.",
      "You could build an INDEX on a matching displayValue, and then JOIN the arrays by updating += the right object in to.json with the corresponding object in from.json:",
      "FIXED: Using try in the join update prevents from failing if the matching is not complete.",
      "jq '\n  [\n    JOIN(\n      INDEX(.[].cells; .[] | select(.columnId == 7408953102493572).displayValue);\n      input[];\n      .cells[] | select(.columnId == 5460306864433028).displayValue;\n      (.[0].cells[] | select(.columnId == 5206337428711300)) += try\n        (.[1][] | select(.columnId == 5822630258337668) | del(.Column, .columnId))\n    )[0]\n  ]\n' from.json to.json"
    ],
    "utterance": "Update each object in the target array so that for every cell with columnId 5206337428711300, if there is a matching value in the source array based on displayValue in the cell with columnId 5460306864433028, add all key-value pairs except Column and columnId from the corresponding cell with columnId 5822630258337668.",
    "expressions": [
      "[\n  JOIN(\n    INDEX(.[].cells; .[] | select(.columnId == 7408953102493572).displayValue);\n    input[];\n    .cells[] | select(.columnId == 5460306864433028).displayValue;\n    (.[0].cells[] | select(.columnId == 5206337428711300)) += try\n      (.[1][] | select(.columnId == 5822630258337668) | del(.Column, .columnId))\n  )[0]\n]"
    ],
    "data": [
      {
        "input": {
          "from_file": [
            {
              "id": 7212486534162308,
              "rowNumber": 283,
              "cells": [
                {
                  "Column": "SS name",
                  "columnId": 7408953102493572,
                  "displayValue": "Dd Kk",
                  "linkInFromCell": {
                    "status": "OK",
                    "sheetId": 4409864198875012,
                    "rowId": 5483738575202180,
                    "columnId": 6482434207311748,
                    "sheetName": "INFORMATION - J-1000579"
                  },
                  "value": "Dd Kk"
                },
                {
                  "Column": "link",
                  "columnId": 5822630258337668,
                  "displayValue": "Dd Kk link",
                  "hyperlink": {
                    "url": "https://app.test.com/fvffvs/dfesfrfr"
                  },
                  "linkInFromCell": {
                    "status": "OK",
                    "sheetId": 316850291664772,
                    "rowId": 6836472364722052,
                    "columnId": 6189414452881284,
                    "sheetName": "PROJECT INTAKE SHEET"
                  },
                  "value": "Dd Kk"
                }
              ]
            },
            {
              "id": 7046413570598788,
              "rowNumber": 284,
              "cells": [
                {
                  "Column": "SS name",
                  "columnId": 7408953102493572,
                  "displayValue": "Macquarie Education Programs",
                  "linkInFromCell": {
                    "status": "OK",
                    "sheetId": 8275059887368068,
                    "rowId": 8307181892986756,
                    "columnId": 687741640959876,
                    "sheetName": "INFORMATION - J-1000532.01"
                  },
                  "value": "Macquarie Education Programs"
                },
                {
                  "Column": "link",
                  "columnId": 5822630258337668,
                  "displayValue": "Macquarie Education Programs Building - J-10005",
                  "hyperlink": {
                    "url": "https://app.test.com/jnjnnlkm/fvfbsfbfgvdsfe"
                  },
                  "linkInFromCell": {
                    "status": "OK",
                    "sheetId": 316850291664772,
                    "rowId": 4795289157298052,
                    "columnId": 6189414452881284,
                    "sheetName": "PROJECT INTAKE SHEET"
                  },
                  "value": "Macquarie Education Programs - J-10005"
                }
              ]
            }
          ],
          "to_file": [
            {
              "id": 977325251291012,
              "cells": [
                {
                  "columnId": 2040705442965380,
                  "value": true
                },
                {
                  "columnId": 5206337428711300,
                  "value": ""
                },
                {
                  "columnId": 5460306864433028,
                  "value": "Dd Kk",
                  "displayValue": "Dd Kk"
                }
              ]
            },
            {
              "id": 5480924878661508,
              "cells": [
                {
                  "columnId": 2040705442965380,
                  "value": true
                },
                {
                  "columnId": 5206337428711300
                },
                {
                  "columnId": 5460306864433028,
                  "value": "Macquarie Education Programs",
                  "displayValue": "Macquarie Education Programs"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "id": 977325251291012,
            "cells": [
              {
                "columnId": 2040705442965380,
                "value": true
              },
              {
                "columnId": 5206337428711300,
                "displayValue": "Dd Kk link",
                "hyperlink": {
                  "url": "https://app.test.com/fvffvs/dfesfrfr"
                },
                "linkInFromCell": {
                  "status": "OK",
                  "sheetId": 316850291664772,
                  "rowId": 6836472364722052,
                  "columnId": 6189414452881284,
                  "sheetName": "PROJECT INTAKE SHEET"
                },
                "value": "Dd Kk"
              },
              {
                "columnId": 5460306864433028,
                "value": "Dd Kk",
                "displayValue": "Dd Kk"
              }
            ]
          },
          {
            "id": 5480924878661508,
            "cells": [
              {
                "columnId": 2040705442965380,
                "value": true
              },
              {
                "columnId": 5206337428711300,
                "displayValue": "Macquarie Education Programs Building - J-10005",
                "hyperlink": {
                  "url": "https://app.test.com/jnjnnlkm/fvfbsfbfgvdsfe"
                },
                "linkInFromCell": {
                  "status": "OK",
                  "sheetId": 316850291664772,
                  "rowId": 4795289157298052,
                  "columnId": 6189414452881284,
                  "sheetName": "PROJECT INTAKE SHEET"
                },
                "value": "Macquarie Education Programs - J-10005"
              },
              {
                "columnId": 5460306864433028,
                "value": "Macquarie Education Programs",
                "displayValue": "Macquarie Education Programs"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 71670051
  },
  {
    "context": [
      "I have an array of vulnerabilities with duplicate hostnames and vulns. I would like to output an object by hostname and IP to include a list of vulnerabilities associated to that host.",
      "What I'm missing is an array of \"Vuln\" objects to include values like proof, description, and title for each nexposeid.",
      "If you prefer the .Vuln field to be an array of objects, here's a solution using unique_by:",
      "jq '\n  group_by(.\"Host Name\") | map(\n    (.[0] | {\"Host Name\", \"IP Address\"}) +\n    {Vuln: unique_by(.NexposeID) | map(\n      {Proof, \"Vulnerability Description\", \" Vulnerability Title\"}\n    )}\n  )\n'",
      "Output:\n[\n  {\n    \"Host Name\": \"host1\",\n    \"IP Address\": \"10.1.10.20\",\n    \"Vuln\": [\n      { ... },\n      ...\n    ]\n  },\n  {\n    \"Host Name\": \"host2\",\n    \"IP Address\": \"10.1.10.10\",\n    \"Vuln\": [\n      { ... },\n      ...\n    ]\n  }\n]"
    ],
    "utterance": "Group array elements by Host Name and IP Address, and for each group, return an array of unique vulnerability objects containing Proof, Vulnerability Description, and Vulnerability Title",
    "expressions": [
      "group_by(.\"Host Name\") | map((.[0] | {\"Host Name\", \"IP Address\"}) + {Vuln: unique_by(.NexposeID) | map({Proof, \"Vulnerability Description\", \" Vulnerability Title\"})})"
    ],
    "data": [
      {
        "input": [
          {
            " Vulnerability Title": "Apache Log4j Core: CVE-2021-45046: Apache Log4j2 Thread Context Lookup Pattern vulnerable to remote code execution in certain non-default configurations",
            "Host Name": "host1",
            "IP Address": "10.1.10.20",
            "NexposeID": "apache-log4j-core-cve-2021-45046",
            "Proof": "Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)No mitigation applied. JndiLookup class discovered.",
            "Proof Key": "/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar",
            "Solution Fix": "Download and apply the patch from: https://logging.apache.org/log4j/2.x/download.html (https://logging.apache.org/log4j/2.x/download.html)",
            "Solution Summary": "Upgrade Apache Log4j Core to the latest version",
            "Solution Type": "PATCH",
            "Solution url": "https://logging.apache.org/log4j/2.x/download.html",
            "Vulnerability Description": "It was found that the fix to address CVE-2021-44228 in Apache Log4j 2.15.0 was incomplete in certain non-default configurations. When the logging configuration uses a non-default Pattern Layout with a Context Lookup (for example, $${ctx:loginId}), attackers with control over Thread Context Map (MDC) input data can craft malicious input data using a JNDI Lookup pattern, resulting in an information leak and remote code execution in some environments and local code execution in all environments; remote code execution has been demonstrated on macOS but no other tested environments."
          },
          {
            " Vulnerability Title": "Apache Log4j Core: CVE-2021-45105: Apache Log4j2 does not always protect from infinite recursion in lookup evaluation",
            "Host Name": "host1",
            "IP Address": "10.1.10.20",
            "NexposeID": "apache-log4j-core-cve-2021-45105",
            "Proof": "Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)",
            "Proof Key": "/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar",
            "Solution Fix": "Download and apply the patch from: https://logging.apache.org/log4j/2.x/download.html (https://logging.apache.org/log4j/2.x/download.html)",
            "Solution Summary": "Upgrade Apache Log4j Core to 2.12.3",
            "Solution Type": "PATCH",
            "Solution url": "https://logging.apache.org/log4j/2.x/download.html",
            "Vulnerability Description": "Apache Log4j2 versions 2.0-alpha1 through 2.16.0 did not protect from uncontrolled recursion from self-referential lookups. When the logging configuration uses a non-default Pattern Layout with a Context Lookup (for example, $${ctx:loginId}), attackers with control over Thread Context Map (MDC) input data can craft malicious input data that contains a recursive lookup, resulting in a StackOverflowError that will terminate the process. This is also known as a DOS (Denial of Service) attack."
          },
          {
            " Vulnerability Title": "Apache Log4j Core: CVE-2021-44228: JNDI support has not restricted what names could be resolved allowing remote code execution",
            "Host Name": "host2",
            "IP Address": "10.1.10.10",
            "NexposeID": "apache-log4j-core-cve-2021-44228",
            "Proof": "Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)No mitigation applied. JndiLookup class discovered.",
            "Proof Key": "/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar",
            "Solution Fix": "Download and apply the patch from: https://logging.apache.org/log4j/2.x/download.html (https://logging.apache.org/log4j/2.x/download.html)",
            "Solution Summary": "Upgrade Apache Log4j Core to the latest version",
            "Solution Type": "PATCH",
            "Solution url": "https://logging.apache.org/log4j/2.x/download.html",
            "Vulnerability Description": "One vector that allowed exposure to this vulnerability was Log4j\u2019s allowance of Lookups to appear in log messages. This meant that when user input is logged, and that user input contained a JNDI Lookup pointing to a malicious server, then Log4j would resolve that JNDI Lookup, connect to that server, and potentially download serialized Java code from that remote server. This in turn could execute any code during deserialization. This is known as a RCE (Remote Code Execution) attack. In version 2.12.2 Log4j disables access to JNDI by default. Usage of JNDI in configuration now need to be enabled explicitly. Calls to the JndiLookup will now return a constant string. Also, Log4j now limits the protocols by default to only java. The message lookups feature has been completely removed. In version 2.16.0 the message lookups feature has been completely removed. Lookups in configuration still work. Furthermore, Log4j now disables access to JNDI by default. JNDI lookups in configuration now need to be enabled explicitly. Also, Log4j now limits the protocols by default to only java, ldap, and ldaps and limits the ldap protocols to only accessing Java primitive objects. Hosts other than the local host need to be explicitly allowed. This check requires the Security Console and Scan Engines to be on product version 6.6.118 or later."
          }
        ],
        "output": [
          {
            "Host Name": "host1",
            "IP Address": "10.1.10.20",
            "Vuln": [
              {
                "Proof": "Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)No mitigation applied. JndiLookup class discovered.",
                "Vulnerability Description": "It was found that the fix to address CVE-2021-44228 in Apache Log4j 2.15.0 was incomplete in certain non-default configurations. When the logging configuration uses a non-default Pattern Layout with a Context Lookup (for example, $${ctx:loginId}), attackers with control over Thread Context Map (MDC) input data can craft malicious input data using a JNDI Lookup pattern, resulting in an information leak and remote code execution in some environments and local code execution in all environments; remote code execution has been demonstrated on macOS but no other tested environments.",
                " Vulnerability Title": "Apache Log4j Core: CVE-2021-45046: Apache Log4j2 Thread Context Lookup Pattern vulnerable to remote code execution in certain non-default configurations"
              },
              {
                "Proof": "Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)",
                "Vulnerability Description": "Apache Log4j2 versions 2.0-alpha1 through 2.16.0 did not protect from uncontrolled recursion from self-referential lookups. When the logging configuration uses a non-default Pattern Layout with a Context Lookup (for example, $${ctx:loginId}), attackers with control over Thread Context Map (MDC) input data can craft malicious input data that contains a recursive lookup, resulting in a StackOverflowError that will terminate the process. This is also known as a DOS (Denial of Service) attack.",
                " Vulnerability Title": "Apache Log4j Core: CVE-2021-45105: Apache Log4j2 does not always protect from infinite recursion in lookup evaluation"
              }
            ]
          },
          {
            "Host Name": "host2",
            "IP Address": "10.1.10.10",
            "Vuln": [
              {
                "Proof": "Vulnerable software installed: Apache Log4j Core 2.8.2 (/opt/IBM/WebSphere/AppServer/properties/patches/backup/9.0.5.3-WS-WASProd-IFPH42762/systemApps/isclite.ear/kc.war/WEB-INF/lib/log4j-core-2.8.2.jar)No mitigation applied. JndiLookup class discovered.",
                "Vulnerability Description": "One vector that allowed exposure to this vulnerability was Log4j\u2019s allowance of Lookups to appear in log messages. This meant that when user input is logged, and that user input contained a JNDI Lookup pointing to a malicious server, then Log4j would resolve that JNDI Lookup, connect to that server, and potentially download serialized Java code from that remote server. This in turn could execute any code during deserialization. This is known as a RCE (Remote Code Execution) attack. In version 2.12.2 Log4j disables access to JNDI by default. Usage of JNDI in configuration now need to be enabled explicitly. Calls to the JndiLookup will now return a constant string. Also, Log4j now limits the protocols by default to only java. The message lookups feature has been completely removed. In version 2.16.0 the message lookups feature has been completely removed. Lookups in configuration still work. Furthermore, Log4j now disables access to JNDI by default. JNDI lookups in configuration now need to be enabled explicitly. Also, Log4j now limits the protocols by default to only java, ldap, and ldaps and limits the ldap protocols to only accessing Java primitive objects. Hosts other than the local host need to be explicitly allowed. This check requires the Security Console and Scan Engines to be on product version 6.6.118 or later.",
                " Vulnerability Title": "Apache Log4j Core: CVE-2021-44228: JNDI support has not restricted what names could be resolved allowing remote code execution"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 71770482
  },
  {
    "context": [
      "How do I programatically search for an object which may not be in the same location for each file and remove it?",
      "It would be more ideal if there was an option in PowerShell to find all instances of objects named `metadata` and remove them, but I cannot find an option like this in PowerShell.",
      "More of a \"look for all of `*.metadata` and remove from object, where ever it is\".",
      "As `jq` is tagged, you can use `walk` to traverse the JSON document, and if it encounters an object, apply `del` to delete any `.metadata` field:\r\n~~~sh\r\njq 'walk(if type == \"object\" then del(.metadata) else . end)' file.json\r\n~~~"
    ],
    "utterance": "Remove all properties named metadata from every object, regardless of their location or depth in the structure.",
    "expressions": [
      "walk(if type == \"object\" then del(.metadata) else . end)"
    ],
    "data": [
      {
        "input": {
          "$schema": "https://schema.management.azure.com/schemas/2018-05-01/subscriptionDeploymentTemplate.json#",
          "contentVersion": "1.0.0.0",
          "metadata": {
            "_generator": {
              "name": "bicep",
              "version": "0.4.1111.15138",
              "templateHash": "asdfasdfasdf"
            }
          },
          "parameters": {
            "p_vnetPeeringsCompute": {
              "type": "array",
              "metadata": {
                "description": "List of peerings to the virtual network."
              }
            },
            "p_vnetPeeringsStorage": {
              "type": "array",
              "metadata": {
                "description": "List of peerings to the virtual network."
              }
            },
            "p_vnetPeeringsLinkFile": {
              "type": "array",
              "metadata": {
                "description": "List of peerings to the virtual network."
              }
            },
            "p_tags": {
              "type": "object",
              "defaultValue": {},
              "metadata": {
                "description": "List of tags applied to resources."
              }
            }
          },
          "functions": [],
          "variables": {
            "v_longLocation": "uksouth",
            "v_shortLocation": "uks",
            "v_templateDescription": "Azure Private DNS Template Spec",
            "v_templateDisplayName": "privateDns",
            "v_templateName": "privateDns",
            "v_templateVersion": "2.0.0",
            "v_templateTags": {
              "tsName": "[variables('v_templateName')]",
              "tsVersion": "[variables('v_templateVersion')]"
            },
            "v_tags": "[union(parameters('p_tags'), variables('v_templateTags'))]"
          },
          "resources": [
            {
              "type": "Microsoft.Resources/resourceGroups",
              "apiVersion": "2021-01-01",
              "name": "[format('{0}-{1}-compute-rsg', variables('v_shortLocation'), subscription().displayName)]",
              "location": "[variables('v_longLocation')]",
              "tags": "[variables('v_tags')]"
            },
            {
              "type": "Microsoft.Resources/resourceGroups",
              "apiVersion": "2021-01-01",
              "name": "[format('{0}-{1}-link-rsg', variables('v_shortLocation'), subscription().displayName)]",
              "location": "[variables('v_longLocation')]",
              "tags": "[variables('v_tags')]"
            },
            {
              "type": "Microsoft.Resources/resourceGroups",
              "apiVersion": "2021-01-01",
              "name": "[format('{0}-{1}-storage-rsg', variables('v_shortLocation'), subscription().displayName)]",
              "location": "[variables('v_longLocation')]",
              "tags": "[variables('v_tags')]"
            },
            {
              "type": "Microsoft.Resources/deployments",
              "apiVersion": "2020-06-01",
              "name": "privateCompute",
              "resourceGroup": "[format('{0}-{1}-compute-rsg', variables('v_shortLocation'), subscription().displayName)]",
              "properties": {
                "expressionEvaluationOptions": {
                  "scope": "inner"
                },
                "mode": "Incremental",
                "parameters": {
                  "p_tags": {
                    "value": "[variables('v_tags')]"
                  },
                  "p_vnetPeeringsCompute": {
                    "value": "[parameters('p_vnetPeeringsCompute')]"
                  }
                },
                "template": {
                  "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
                  "contentVersion": "1.0.0.0",
                  "metadata": {
                    "_generator": {
                      "name": "bicep",
                      "version": "0.4.1008.15138",
                      "templateHash": "17593852815978663805"
                    }
                  },
                  "parameters": {
                    "p_tags": {
                      "type": "object",
                      "defaultValue": {},
                      "metadata": {
                        "description": "List of tags applied to resources."
                      }
                    },
                    "p_vnetPeeringsCompute": {
                      "type": "array",
                      "metadata": {
                        "description": "List of peerings to the virtual network."
                      }
                    }
                  },
                  "functions": [],
                  "resources": [
                    {
                      "type": "Microsoft.Network/privateDnsZones",
                      "apiVersion": "2020-06-01",
                      "name": "compute.bld.local",
                      "tags": "[parameters('p_tags')]",
                      "location": "Global"
                    },
                    {
                      "copy": {
                        "name": "vnl",
                        "count": "[length(parameters('p_vnetPeeringsCompute'))]"
                      },
                      "type": "Microsoft.Network/privateDnsZones/virtualNetworkLinks",
                      "apiVersion": "2020-06-01",
                      "name": "[format('{0}/{1}', 'compute.bld.local', last(split(parameters('p_vnetPeeringsCompute')[copyIndex()].id, '/')))]",
                      "tags": "[parameters('p_tags')]",
                      "location": "Global",
                      "properties": {
                        "virtualNetwork": {
                          "id": "[parameters('p_vnetPeeringsCompute')[copyIndex()].id]"
                        },
                        "registrationEnabled": false
                      },
                      "dependsOn": [
                        "[resourceId('Microsoft.Network/privateDnsZones', 'compute.bld.local')]"
                      ]
                    }
                  ]
                }
              },
              "dependsOn": [
                "[subscriptionResourceId('Microsoft.Resources/resourceGroups', format('{0}-{1}-compute-rsg', variables('v_shortLocation'), subscription().displayName))]"
              ]
            },
            {
              "type": "Microsoft.Resources/deployments",
              "apiVersion": "2020-06-01",
              "name": "privateLink",
              "resourceGroup": "[format('{0}-{1}-link-rsg', variables('v_shortLocation'), subscription().displayName)]",
              "properties": {
                "expressionEvaluationOptions": {
                  "scope": "inner"
                },
                "mode": "Incremental",
                "parameters": {
                  "p_vnetPeeringsLinkFile": {
                    "value": "[parameters('p_vnetPeeringsLinkFile')]"
                  },
                  "p_tags": {
                    "value": "[variables('v_tags')]"
                  }
                },
                "template": {
                  "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
                  "contentVersion": "1.0.0.0",
                  "metadata": {
                    "_generator": {
                      "name": "bicep",
                      "version": "0.4.1008.15138",
                      "templateHash": "14603239311913824090"
                    }
                  },
                  "parameters": {
                    "p_vnetPeeringsLinkFile": {
                      "type": "array",
                      "metadata": {
                        "description": "List of peerings to the virtual network."
                      }
                    },
                    "p_tags": {
                      "type": "object",
                      "defaultValue": {},
                      "metadata": {
                        "description": "List of tags applied to resources."
                      }
                    }
                  },
                  "functions": [],
                  "resources": [
                    {
                      "type": "Microsoft.Network/privateDnsZones",
                      "apiVersion": "2020-06-01",
                      "name": "[format('privatelink.file.{0}', environment().suffixes.storage)]",
                      "tags": "[parameters('p_tags')]",
                      "location": "Global"
                    },
                    {
                      "copy": {
                        "name": "vnl",
                        "count": "[length(parameters('p_vnetPeeringsLinkFile'))]"
                      },
                      "type": "Microsoft.Network/privateDnsZones/virtualNetworkLinks",
                      "apiVersion": "2020-06-01",
                      "name": "[format('{0}/{1}', format('privatelink.file.{0}', environment().suffixes.storage), last(split(parameters('p_vnetPeeringsLinkFile')[copyIndex()].id, '/')))]",
                      "tags": "[parameters('p_tags')]",
                      "location": "Global",
                      "properties": {
                        "virtualNetwork": {
                          "id": "[parameters('p_vnetPeeringsLinkFile')[copyIndex()].id]"
                        },
                        "registrationEnabled": false
                      },
                      "dependsOn": [
                        "[resourceId('Microsoft.Network/privateDnsZones', format('privatelink.file.{0}', environment().suffixes.storage))]"
                      ]
                    },
                    {
                      "type": "Microsoft.Network/privateDnsZones",
                      "apiVersion": "2020-06-01",
                      "name": "[format('privatelink{0}', environment().suffixes.sqlServerHostname)]",
                      "tags": "[parameters('p_tags')]",
                      "location": "Global"
                    }
                  ]
                }
              },
              "dependsOn": [
                "[subscriptionResourceId('Microsoft.Resources/resourceGroups', format('{0}-{1}-link-rsg', variables('v_shortLocation'), subscription().displayName))]"
              ]
            },
            {
              "type": "Microsoft.Resources/deployments",
              "apiVersion": "2020-06-01",
              "name": "privateStorage",
              "resourceGroup": "[format('{0}-{1}-storage-rsg', variables('v_shortLocation'), subscription().displayName)]",
              "properties": {
                "expressionEvaluationOptions": {
                  "scope": "inner"
                },
                "mode": "Incremental",
                "parameters": {
                  "p_tags": {
                    "value": "[variables('v_tags')]"
                  },
                  "p_vnetPeeringsStorage": {
                    "value": "[parameters('p_vnetPeeringsStorage')]"
                  }
                },
                "template": {
                  "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
                  "contentVersion": "1.0.0.0",
                  "metadata": {
                    "_generator": {
                      "name": "bicep",
                      "version": "0.4.1008.15138",
                      "templateHash": "12131108274222647600"
                    }
                  },
                  "parameters": {
                    "p_tags": {
                      "type": "object",
                      "defaultValue": {},
                      "metadata": {
                        "description": "List of tags applied to resources."
                      }
                    },
                    "p_vnetPeeringsStorage": {
                      "type": "array",
                      "metadata": {
                        "description": "List of peerings to the virtual network."
                      }
                    }
                  },
                  "functions": [],
                  "resources": [
                    {
                      "type": "Microsoft.Network/privateDnsZones",
                      "apiVersion": "2020-06-01",
                      "name": "storage.bld.local",
                      "tags": "[parameters('p_tags')]",
                      "location": "Global"
                    },
                    {
                      "copy": {
                        "name": "vnl",
                        "count": "[length(parameters('p_vnetPeeringsStorage'))]"
                      },
                      "type": "Microsoft.Network/privateDnsZones/virtualNetworkLinks",
                      "apiVersion": "2020-06-01",
                      "name": "[format('{0}/{1}', 'storage.bld.local', last(split(parameters('p_vnetPeeringsStorage')[copyIndex()].id, '/')))]",
                      "tags": "[parameters('p_tags')]",
                      "location": "Global",
                      "properties": {
                        "virtualNetwork": {
                          "id": "[parameters('p_vnetPeeringsStorage')[copyIndex()].id]"
                        },
                        "registrationEnabled": false
                      },
                      "dependsOn": [
                        "[resourceId('Microsoft.Network/privateDnsZones', 'storage.bld.local')]"
                      ]
                    }
                  ]
                }
              },
              "dependsOn": [
                "[subscriptionResourceId('Microsoft.Resources/resourceGroups', format('{0}-{1}-storage-rsg', variables('v_shortLocation'), subscription().displayName))]"
              ]
            }
          ]
        },
        "output": {
          "$schema": "https://schema.management.azure.com/schemas/2018-05-01/subscriptionDeploymentTemplate.json#",
          "contentVersion": "1.0.0.0",
          "parameters": {
            "p_vnetPeeringsCompute": {
              "type": "array"
            },
            "p_vnetPeeringsStorage": {
              "type": "array"
            },
            "p_vnetPeeringsLinkFile": {
              "type": "array"
            },
            "p_tags": {
              "type": "object",
              "defaultValue": {}
            }
          },
          "functions": [],
          "variables": {
            "v_longLocation": "uksouth",
            "v_shortLocation": "uks",
            "v_templateDescription": "Azure Private DNS Template Spec",
            "v_templateDisplayName": "privateDns",
            "v_templateName": "privateDns",
            "v_templateVersion": "2.0.0",
            "v_templateTags": {
              "tsName": "[variables('v_templateName')]",
              "tsVersion": "[variables('v_templateVersion')]"
            },
            "v_tags": "[union(parameters('p_tags'), variables('v_templateTags'))]"
          },
          "resources": [
            {
              "type": "Microsoft.Resources/resourceGroups",
              "apiVersion": "2021-01-01",
              "name": "[format('{0}-{1}-compute-rsg', variables('v_shortLocation'), subscription().displayName)]",
              "location": "[variables('v_longLocation')]",
              "tags": "[variables('v_tags')]"
            },
            {
              "type": "Microsoft.Resources/resourceGroups",
              "apiVersion": "2021-01-01",
              "name": "[format('{0}-{1}-link-rsg', variables('v_shortLocation'), subscription().displayName)]",
              "location": "[variables('v_longLocation')]",
              "tags": "[variables('v_tags')]"
            },
            {
              "type": "Microsoft.Resources/resourceGroups",
              "apiVersion": "2021-01-01",
              "name": "[format('{0}-{1}-storage-rsg', variables('v_shortLocation'), subscription().displayName)]",
              "location": "[variables('v_longLocation')]",
              "tags": "[variables('v_tags')]"
            },
            {
              "type": "Microsoft.Resources/deployments",
              "apiVersion": "2020-06-01",
              "name": "privateCompute",
              "resourceGroup": "[format('{0}-{1}-compute-rsg', variables('v_shortLocation'), subscription().displayName)]",
              "properties": {
                "expressionEvaluationOptions": {
                  "scope": "inner"
                },
                "mode": "Incremental",
                "parameters": {
                  "p_tags": {
                    "value": "[variables('v_tags')]"
                  },
                  "p_vnetPeeringsCompute": {
                    "value": "[parameters('p_vnetPeeringsCompute')]"
                  }
                },
                "template": {
                  "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
                  "contentVersion": "1.0.0.0",
                  "parameters": {
                    "p_tags": {
                      "type": "object",
                      "defaultValue": {}
                    },
                    "p_vnetPeeringsCompute": {
                      "type": "array"
                    }
                  },
                  "functions": [],
                  "resources": [
                    {
                      "type": "Microsoft.Network/privateDnsZones",
                      "apiVersion": "2020-06-01",
                      "name": "compute.bld.local",
                      "tags": "[parameters('p_tags')]",
                      "location": "Global"
                    },
                    {
                      "copy": {
                        "name": "vnl",
                        "count": "[length(parameters('p_vnetPeeringsCompute'))]"
                      },
                      "type": "Microsoft.Network/privateDnsZones/virtualNetworkLinks",
                      "apiVersion": "2020-06-01",
                      "name": "[format('{0}/{1}', 'compute.bld.local', last(split(parameters('p_vnetPeeringsCompute')[copyIndex()].id, '/')))]",
                      "tags": "[parameters('p_tags')]",
                      "location": "Global",
                      "properties": {
                        "virtualNetwork": {
                          "id": "[parameters('p_vnetPeeringsCompute')[copyIndex()].id]"
                        },
                        "registrationEnabled": false
                      },
                      "dependsOn": [
                        "[resourceId('Microsoft.Network/privateDnsZones', 'compute.bld.local')]"
                      ]
                    }
                  ]
                }
              },
              "dependsOn": [
                "[subscriptionResourceId('Microsoft.Resources/resourceGroups', format('{0}-{1}-compute-rsg', variables('v_shortLocation'), subscription().displayName))]"
              ]
            },
            {
              "type": "Microsoft.Resources/deployments",
              "apiVersion": "2020-06-01",
              "name": "privateLink",
              "resourceGroup": "[format('{0}-{1}-link-rsg', variables('v_shortLocation'), subscription().displayName)]",
              "properties": {
                "expressionEvaluationOptions": {
                  "scope": "inner"
                },
                "mode": "Incremental",
                "parameters": {
                  "p_vnetPeeringsLinkFile": {
                    "value": "[parameters('p_vnetPeeringsLinkFile')]"
                  },
                  "p_tags": {
                    "value": "[variables('v_tags')]"
                  }
                },
                "template": {
                  "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
                  "contentVersion": "1.0.0.0",
                  "parameters": {
                    "p_vnetPeeringsLinkFile": {
                      "type": "array"
                    },
                    "p_tags": {
                      "type": "object",
                      "defaultValue": {}
                    }
                  },
                  "functions": [],
                  "resources": [
                    {
                      "type": "Microsoft.Network/privateDnsZones",
                      "apiVersion": "2020-06-01",
                      "name": "[format('privatelink.file.{0}', environment().suffixes.storage)]",
                      "tags": "[parameters('p_tags')]",
                      "location": "Global"
                    },
                    {
                      "copy": {
                        "name": "vnl",
                        "count": "[length(parameters('p_vnetPeeringsLinkFile'))]"
                      },
                      "type": "Microsoft.Network/privateDnsZones/virtualNetworkLinks",
                      "apiVersion": "2020-06-01",
                      "name": "[format('{0}/{1}', format('privatelink.file.{0}', environment().suffixes.storage), last(split(parameters('p_vnetPeeringsLinkFile')[copyIndex()].id, '/')))]",
                      "tags": "[parameters('p_tags')]",
                      "location": "Global",
                      "properties": {
                        "virtualNetwork": {
                          "id": "[parameters('p_vnetPeeringsLinkFile')[copyIndex()].id]"
                        },
                        "registrationEnabled": false
                      },
                      "dependsOn": [
                        "[resourceId('Microsoft.Network/privateDnsZones', format('privatelink.file.{0}', environment().suffixes.storage))]"
                      ]
                    },
                    {
                      "type": "Microsoft.Network/privateDnsZones",
                      "apiVersion": "2020-06-01",
                      "name": "[format('privatelink{0}', environment().suffixes.sqlServerHostname)]",
                      "tags": "[parameters('p_tags')]",
                      "location": "Global"
                    }
                  ]
                }
              },
              "dependsOn": [
                "[subscriptionResourceId('Microsoft.Resources/resourceGroups', format('{0}-{1}-link-rsg', variables('v_shortLocation'), subscription().displayName))]"
              ]
            },
            {
              "type": "Microsoft.Resources/deployments",
              "apiVersion": "2020-06-01",
              "name": "privateStorage",
              "resourceGroup": "[format('{0}-{1}-storage-rsg', variables('v_shortLocation'), subscription().displayName)]",
              "properties": {
                "expressionEvaluationOptions": {
                  "scope": "inner"
                },
                "mode": "Incremental",
                "parameters": {
                  "p_tags": {
                    "value": "[variables('v_tags')]"
                  },
                  "p_vnetPeeringsStorage": {
                    "value": "[parameters('p_vnetPeeringsStorage')]"
                  }
                },
                "template": {
                  "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
                  "contentVersion": "1.0.0.0",
                  "parameters": {
                    "p_tags": {
                      "type": "object",
                      "defaultValue": {}
                    },
                    "p_vnetPeeringsStorage": {
                      "type": "array"
                    }
                  },
                  "functions": [],
                  "resources": [
                    {
                      "type": "Microsoft.Network/privateDnsZones",
                      "apiVersion": "2020-06-01",
                      "name": "storage.bld.local",
                      "tags": "[parameters('p_tags')]",
                      "location": "Global"
                    },
                    {
                      "copy": {
                        "name": "vnl",
                        "count": "[length(parameters('p_vnetPeeringsStorage'))]"
                      },
                      "type": "Microsoft.Network/privateDnsZones/virtualNetworkLinks",
                      "apiVersion": "2020-06-01",
                      "name": "[format('{0}/{1}', 'storage.bld.local', last(split(parameters('p_vnetPeeringsStorage')[copyIndex()].id, '/')))]",
                      "tags": "[parameters('p_tags')]",
                      "location": "Global",
                      "properties": {
                        "virtualNetwork": {
                          "id": "[parameters('p_vnetPeeringsStorage')[copyIndex()].id]"
                        },
                        "registrationEnabled": false
                      },
                      "dependsOn": [
                        "[resourceId('Microsoft.Network/privateDnsZones', 'storage.bld.local')]"
                      ]
                    }
                  ]
                }
              },
              "dependsOn": [
                "[subscriptionResourceId('Microsoft.Resources/resourceGroups', format('{0}-{1}-storage-rsg', variables('v_shortLocation'), subscription().displayName))]"
              ]
            }
          ]
        }
      }
    ],
    "identifier": 71689656
  }
]