[
  {
    "identifier": 70286089
  },
  {
    "context": [
      "echo \"$3\" | jq -j '.[]|(.ParamName, \"=\\\"\", .ParamVal, \"\\\"\\n\")' > \"${tmp}\"",
      "echo \"${3}\" | jq '.[]|(.ParamVal)'"
    ],
    "utterance": "Extract the values associated with ParamVal from an array of objects where each object has ParamName and ParamVal fields.",
    "expressions": [
      ".[] | .ParamVal"
    ],
    "data": [
      {
        "input": [
          {
            "ParamName": "HostName",
            "ParamVal": "Host1"
          },
          {
            "ParamName": "TargetMachine",
            "ParamVal": "Machine1"
          }
        ],
        "output": [
          "Host1",
          "Machine1"
        ]
      }
    ],
    "identifier": 70290271
  },
  {
    "context": [
      "podIP=$(jq -r '.items[] | select(.metadata.generateName | test(\\\"${appName}\\\")).status.podIP' $WORKSPACE/pods.json)",
      "podIP=$(jq -r \".items[] | select(.metadata.generateName | test($appName)).status.podIP\" $WORKSPACE/pods.json}"
    ],
    "utterance": "Extract the 'podIP' field of all pods whose metadata.generateName matches a given appName value.",
    "expressions": [
      ".items[] | select(.metadata.generateName | test($appName)).status.podIP"
    ],
    "identifier": 70293450
  },
  {
    "context": [
      "Given an array of JSON objects, all having the same key names (key1, key2, key3) and just one key (key3) whose value is an array, how can it be converted to a long format table?",
      "    .[]| ([.key1,.key2] + (.key3[]|[.])) | @csv",
      "**Desired output:**",
      "key1 | key2 | key3",
      "---- | ---- | ----",
      "A    | 1    | aaa",
      "A    | 1    | bbb",
      "B    | 2    | ccc",
      "B    | 2    | ddd"
    ],
    "utterance": "For each object, output one row per value in key3, keeping key1 and key2 the same, with columns key1, key2, key3.",
    "expressions": [
      ".[]| ([.key1,.key2] + (.key3[]|[.])) | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "key1": "A",
            "key2": 1,
            "key3": [
              "aaa",
              "bbb"
            ]
          },
          {
            "key1": "B",
            "key2": 2,
            "key3": [
              "ccc",
              "ddd"
            ]
          }
        ],
        "output": [
          "A,1,aaa",
          "A,1,bbb",
          "B,2,ccc",
          "B,2,ddd"
        ]
      }
    ],
    "identifier": 70292476
  },
  {
    "context": [
      "But I would like to have:\r\n{\r\n  \"id\": 1,\r\n  \"prop\": [\"aa\", \"bb\"]\r\n}",
      "You need to put values in an array :\r\njq '.first[].second | {id: .id, prop: [.third[].value]}'",
      "Use the `map` builtin to transform the array into just `.value`s:\r\njq '.first[].second | {id: .id, prop: .third | map(.value)}'"
    ],
    "utterance": "For each object in 'first', return an object with the same 'id' and a property 'prop' containing an array of all 'value' strings from its 'third' array.",
    "expressions": [
      ".first[].second | {id: .id, prop: [.third[].value]}",
      ".first[].second | {id: .id, prop: .third | map(.value)}"
    ],
    "data": [
      {
        "input": {
          "first": [
            {
              "second": {
                "id": 1,
                "third": [
                  {
                    "value": "aa"
                  },
                  {
                    "value": "bb"
                  }
                ]
              }
            }
          ]
        },
        "output": {
          "id": 1,
          "prop": [
            "aa",
            "bb"
          ]
        }
      }
    ],
    "identifier": 70295210
  },
  {
    "context": [
      "how do you concatenate `items` with JQ into a single array like:\r\n\r\n[\r\n  1,\r\n  2,\r\n  3,\r\n  3,\r\n  4,\r\n  8,\r\n  9\r\n]",
      "Use `flatten`:\r\n\r\nmap(.items) | flatten",
      "Or, `map()` the `items` instantly\r\nmap(.items[])",
      "Or one of the many other options like:\r\n\r\n* [`[ .[].items ] | add`][2]\r\n* [`[ .. | scalars ]`][3]\r\n* [`[ .[][][] ]`][4]",
      "All of those commands will produce:\r\n[\r\n  1,\r\n  2,\r\n  3,\r\n  3,\r\n  4,\r\n  8,\r\n  9\r\n]"
    ],
    "utterance": "Combine all the values from each object's items key into a single array containing all numbers.",
    "expressions": [
      "map(.items) | flatten",
      "map(.items[])",
      "[ .[].items ] | add",
      "[ .. | scalars ]",
      "[ .[][][] ]"
    ],
    "data": [
      {
        "input": [
          {
            "items": [
              1,
              2,
              3
            ]
          },
          {
            "items": [
              3,
              4
            ]
          },
          {
            "items": [
              8,
              9
            ]
          }
        ],
        "output": [
          1,
          2,
          3,
          3,
          4,
          8,
          9
        ]
      }
    ],
    "identifier": 70292076
  },
  {
    "context": [
      "How can I combine each object's Value with the state string so that I can then filter object to only get the one where Key==Name?",
      "Consider:\n```\n.[] | (.Tags[] | select(.Key==\"Name\").Value) + \", \" + .State.Name\n```"
    ],
    "utterance": "Get the value where Key equals Name and combine it with the instance state name as a single comma-separated string.",
    "expressions": [
      ".[] | (.Tags[] | select(.Key==\"Name\").Value) + \", \" + .State.Name"
    ],
    "identifier": 70297189
  },
  {
    "context": [
      "I want to add a fifth element \"group4\" to the array to get ...",
      "Is it possible to add an item without losing the previous one?",
      "You want `.packages |= . + [ { ... } ]`, which appends an element (well, an entire array, really), to the `packages` array, and not `.packages[3] |= { ... }`, which adds/merges some keys into the object at `.packages[3]`.",
      "jq '.packages |= .[:3] + [{Group: \"group4\", Name: \"name4\", Version: \"1.0.0\"}] + .[3:]'",
      ".packages |= ( . + [ { \"Group\": \"group4\", \"Name\": \"name4\", \"Version\": \"1.0.0\" } ] | sort_by( .Group ) )"
    ],
    "utterance": "Insert a new object with Group \"group4\", Name \"name4\", and Version \"1.0.0\" into the packages array between group3 and group5, preserving all existing elements.",
    "expressions": [
      ".packages |= .[:3] + [{\"Group\": \"group4\", \"Name\": \"name4\", \"Version\": \"1.0.0\"}] + .[3:]",
      ".packages |= ( . + [ { \"Group\": \"group4\", \"Name\": \"name4\", \"Version\": \"1.0.0\" } ] | sort_by( .Group ) )",
      ".packages |= . + [{\"Group\": \"group4\", \"Name\": \"name4\", \"Version\": \"1.0.0\"}]"
    ],
    "data": [
      {
        "input": {
          "id": "json",
          "description": "test",
          "packages": [
            {
              "Group": "group1",
              "Name": "name1",
              "Version": "1.0.0"
            },
            {
              "Group": "group2",
              "Name": "name2",
              "Version": "1.0.0"
            },
            {
              "Group": "group3",
              "Name": "name3",
              "Version": "1.0.0"
            },
            {
              "Group": "group5",
              "Name": "name5",
              "Version": "1.0.0"
            }
          ]
        },
        "output": {
          "id": "json",
          "description": "test",
          "packages": [
            {
              "Group": "group1",
              "Name": "name1",
              "Version": "1.0.0"
            },
            {
              "Group": "group2",
              "Name": "name2",
              "Version": "1.0.0"
            },
            {
              "Group": "group3",
              "Name": "name3",
              "Version": "1.0.0"
            },
            {
              "Group": "group4",
              "Name": "name4",
              "Version": "1.0.0"
            },
            {
              "Group": "group5",
              "Name": "name5",
              "Version": "1.0.0"
            }
          ]
        }
      }
    ],
    "identifier": 70272694
  },
  {
    "context": [
      "I want to see if I can parse the json searching for node bb1-2, for example, and print out the cluster name it belongs to BB1?",
      ".clusters[] |  select(.nodes[].node == \"bb1-2\").name",
      ". as $cluster |\n    .nodes[] |\n    select(.node == \"bb1-2\") |\n    {cluster_name:$cluster.name, node:.}"
    ],
    "utterance": "Find the name of the cluster that contains a node with the value bb1-2.",
    "expressions": [
      ".clusters[] | select(.nodes[].node == \"bb1-2\").name",
      ".clusters[] as $cluster | $cluster.nodes[] | select(.node == \"bb1-2\") | $cluster.name",
      ".clusters[] as $cluster | $cluster.nodes[] | select(.node == \"bb1-2\") | {cluster_name:$cluster.name, node:.}"
    ],
    "data": [
      {
        "input": {
          "clusters": [
            {
              "domain": "crap1",
              "name": "BB1",
              "nodes": [
                {
                  "gpu": null,
                  "node": "bb1-1",
                  "role": "worker"
                },
                {
                  "gpu": {
                    "P40": 2
                  },
                  "node": "bb1-2",
                  "role": "master"
                }
              ],
              "site": "B-place",
              "hardware": "prod-2",
              "timezone": "US/Eastern",
              "type": "CCE",
              "subtype": null
            }
          ]
        },
        "output": "BB1"
      }
    ],
    "identifier": 70303524
  },
  {
    "context": [
      "I need to use jq to extract the id values into a new array where enabled is set to true.",
      "how can i make these two objects into an array of strings instead?",
      "To make an \"array of strings\" instead, use `.id` instead of `{id}` like so",
      "map(select(any(.attributes; .enabled)) | .id)",
      "This should work:\n\n    map(select(any(.attributes; .enabled == true)) | .id)",
      "you could also replace `any(.attributes; .enabled == true)` with just `.attributes.enabled == true`.",
      "Something like:\n\n```sh\n$ jq '[.[] | select(.attributes.enabled) | .id]' input.json\n[\n  \"https://kjkljk./secrets/-/1\",\n  \"https://kjklj./secrets/-/2\"\n]\n```"
    ],
    "utterance": "Extract all id values into an array of strings where attributes.enabled is true.",
    "expressions": [
      "map(select(.attributes.enabled) | .id)",
      "[.[] | select(.attributes.enabled) | .id]",
      "map(select(any(.attributes; .enabled)) | .id)"
    ],
    "data": [
      {
        "input": [
          {
            "attributes": {
              "created": "2021-10-18T12:02:39+00:00",
              "enabled": true,
              "expires": null,
              "notBefore": null
            },
            "contentType": null,
            "id": "https://kjkljk./secrets/-/1",
            "managed": null,
            "name": "pw",
            "tags": {}
          },
          {
            "attributes": {
              "created": "2021-10-18T12:06:16+00:00",
              "enabled": true,
              "expires": null,
              "notBefore": null
            },
            "contentType": "",
            "id": "https://kjklj./secrets/-/2",
            "managed": null,
            "name": "pw",
            "tags": {}
          }
        ],
        "output": [
          "https://kjkljk./secrets/-/1",
          "https://kjklj./secrets/-/2"
        ]
      }
    ],
    "identifier": 70302009
  },
  {
    "context": [
      "for example, i want to delete the \"version\" subkey, and i already tried this command",
      "del(.peers.swp1.version, .peers.swp2.version)",
      "But the thing is, the \"swp1\" and \"swp2\" are the interfaces and are something that can change their name, increase or decrease. So I need a command that works to delete the \"version\" subkeys no matter what the interface name is.",
      "All you need is `map_values` and `del`. ",
      ".peers |= map_values(del(.version))",
      "You can also use this syntax :",
      "del(.peers[].version)|del(.memory)"
    ],
    "utterance": "Remove the 'version' subkey from all peer objects regardless of the interface name under 'peers'.",
    "expressions": [
      ".peers |= map_values(del(.version))",
      "del(.peers[].version)"
    ],
    "data": [
      {
        "input": {
          "peers": {
            "swp1": {
              "hostname": "Spine-01",
              "remoteAs": 65001,
              "version": 4,
              "msgRcvd": 452
            },
            "swp2": {
              "hostname": "Spine-02",
              "remoteAs": 65001,
              "version": 4,
              "msgRcvd": 452
            }
          }
        },
        "output": {
          "peers": {
            "swp1": {
              "hostname": "Spine-01",
              "remoteAs": 65001,
              "msgRcvd": 452
            },
            "swp2": {
              "hostname": "Spine-02",
              "remoteAs": 65001,
              "msgRcvd": 452
            }
          }
        }
      }
    ],
    "identifier": 70313751
  },
  {
    "context": [
      "I need to filter by \"level3value22\" at .[0].children[].children[].level3key2 and flatten this deeply nested json object into an array. The expected result is the following.",
      ".children[] | [.level2key] + (.children[] | select(.level3key2 == \"level3value22\") | [.level3key1] + (.level3key3[] | [.level4key]))",
      "| with_entries(.key |= \"v\\(. + 1)\")"
    ],
    "utterance": "Extract all nested items where level3key2 equals \"level3value22\" and output objects with keys v1 (level1key), v2 (level2key), v3 (level3key1), and v4 (level4key).",
    "expressions": [
      "[.[0] | [.level1key] + ( .children[] | [.level2key] + ( .children[] | select(.level3key2 == \"level3value22\") | [.level3key1] + ( .level3key3[] | [.level4key] ) ) ) | with_entries(.key |= \"v\\(. + 1)\") ]"
    ],
    "data": [
      {
        "input": [
          {
            "level1key": "level1value",
            "children": [
              {
                "level2key": "level2value1",
                "children": [
                  {
                    "level3key1": "ignored",
                    "level3key2": "ignored",
                    "level3key3": [
                      {
                        "level4key": "ignored"
                      }
                    ]
                  },
                  {
                    "level3key1": "level3value1",
                    "level3key2": "level3value22",
                    "level3key3": [
                      {
                        "level4key": "level4value1"
                      }
                    ]
                  },
                  {
                    "level3key1": "level3value2",
                    "level3key2": "level3value22",
                    "level3key3": [
                      {
                        "level4key": "level4value2"
                      }
                    ]
                  }
                ]
              },
              {
                "level2key": "level2value2",
                "children": [
                  {
                    "level3key1": "ignored",
                    "level3key2": "ignored",
                    "level3key3": [
                      {
                        "level4key": "ignored"
                      }
                    ]
                  },
                  {
                    "level3key1": "level3value3",
                    "level3key2": "level3value22",
                    "level3key3": [
                      {
                        "level4key": "level4value3"
                      }
                    ]
                  },
                  {
                    "level3key1": "level3value4",
                    "level3key2": "level3value22",
                    "level3key3": [
                      {
                        "level4key": "level4value4"
                      }
                    ]
                  }
                ]
              }
            ]
          }
        ],
        "output": [
          {
            "v1": "level1value",
            "v2": "level2value1",
            "v3": "level3value1",
            "v4": "level4value1"
          },
          {
            "v1": "level1value",
            "v2": "level2value1",
            "v3": "level3value2",
            "v4": "level4value2"
          },
          {
            "v1": "level1value",
            "v2": "level2value2",
            "v3": "level3value3",
            "v4": "level4value3"
          },
          {
            "v1": "level1value",
            "v2": "level2value2",
            "v3": "level3value4",
            "v4": "level4value4"
          }
        ]
      }
    ],
    "identifier": 70272321
  },
  {
    "context": [
      "I want an output like : \r\n\r\n    12345,Amit\r\n    12345,Anuj",
      "cat AV |jq -r 'to_entries[] | select(.key != \"metadata\") |.value |\"\\(.data1), \\(.name)\"'",
      "[[.. | (.data1?) | select(.!=null)], [.. | (.name?) | select(.!=null)]] \r\n| transpose[] \r\n| @csv",
      "the error raises due to `metadata`, which's one the outermost keys , having no sub-element with key name `data1` or `name`"
    ],
    "utterance": "Extract data1 and name fields for all top-level objects except the key 'metadata', formatted as comma-separated values.",
    "expressions": [
      "to_entries[] | select(.key != \"metadata\") | .value | \"\\(.data1),\\(.name)\"",
      "[[.. | (.data1?) | select(.!=null)], [.. | (.name?) | select(.!=null)]] | transpose[] | @csv"
    ],
    "data": [
      {
        "input": {
          "0cef7017-e6af-4c92-9e7c-4db1d7afc733": {
            "Show": [
              "TEST1",
              "TEST2"
            ],
            "data1": 12345,
            "data2": 1234,
            "name": "Amit",
            "Ref": "group_1",
            "data3": 123
          },
          "metadata": "ThRsmflXIMA5LVlOI8vJ0OoSokw=",
          "eef75ad4-c733-42ac-9c55-dd5aa2d69fad": {
            "Show": [
              "TEST3",
              "TEST4"
            ],
            "data1": 12345,
            "data2": 1234,
            "name": "Anuj",
            "Ref": "group_2",
            "data3": 123
          }
        },
        "output": [
          "12345,Amit",
          "12345,Anuj"
        ]
      }
    ],
    "identifier": 70322346
  },
  {
    "context": [
      "How can I get a summary of all the elements of the entry, but only for each name (here we can see db1 mentioned twice so I'd like something like this):",
      "{\n  \"name\": \"db1\",\n  \"size\": 40010,\n  \"items\": 506,\n  \"mutations\": 8,\n  \"tombstones\": 4,\n  \"views_count\": 8,\n  \"fts_count\": 0,\n  \"index_count\": 1,\n  \"analytics_count\": 0\n}",
      "`--slurp` the input to get an array and then use `group_by` to make groups (arrays) according to any criteria (`.name` in your case). If you want just one for each name, take one (e.g. the `first`) of each such group. Finally, apply `[]` to disassemble the surrounding array.",
      "Note: With a little bit of more effort, you could also `--stream` (and then `reduce`) the input (instead of using `--slurp`) but 18000 lines isn't that big for memories nowadays, so I thought this would be the more reasonable approach."
    ],
    "utterance": "For each unique name, sum all corresponding numeric fields to produce a summary entry per name.",
    "expressions": [
      "jq --slurp 'group_by(.name) | map(reduce .[] as $item ({}; .name = $item.name | .size += $item.size | .items += $item.items | .mutations += $item.mutations | .tombstones += $item.tombstones | .views_count += $item.views_count | .fts_count += $item.fts_count | .index_count += $item.index_count | .analytics_count += $item.analytics_count))[]'"
    ],
    "data": [
      {
        "input": [
          {
            "name": "db1",
            "size": 40000,
            "items": 500,
            "mutations": 2,
            "tombstones": 4,
            "views_count": 8,
            "fts_count": 0,
            "index_count": 0,
            "analytics_count": 0
          },
          {
            "name": "db2",
            "size": 11,
            "items": 900,
            "mutations": 3,
            "tombstones": 0,
            "views_count": 0,
            "fts_count": 0,
            "index_count": 0,
            "analytics_count": 0
          },
          {
            "name": "db1",
            "size": 10,
            "items": 6,
            "mutations": 5,
            "tombstones": 0,
            "views_count": 0,
            "fts_count": 0,
            "index_count": 1,
            "analytics_count": 0
          }
        ],
        "output": [
          {
            "name": "db1",
            "size": 40010,
            "items": 506,
            "mutations": 7,
            "tombstones": 4,
            "views_count": 8,
            "fts_count": 0,
            "index_count": 1,
            "analytics_count": 0
          },
          {
            "name": "db2",
            "size": 11,
            "items": 900,
            "mutations": 3,
            "tombstones": 0,
            "views_count": 0,
            "fts_count": 0,
            "index_count": 0,
            "analytics_count": 0
          }
        ]
      }
    ],
    "identifier": 70305744
  },
  {
    "context": [
      "I want to extract the value for the 'example.io/creatorId' field.",
      "However, when I tried the below script, appending \"example.io/creatorId\", it fails.",
      "jq -r .metadata.annotations.\"example.io/creatorId\"",
      "For the `jq` solution: Put your filter within apostrophes `'` to make it a string.",
      "jq -r '.metadata.annotations.\"example.io/creatorId\"'"
    ],
    "utterance": "Extract the value of the metadata.annotations.\"example.io/creatorId\" field where the key contains dots and slashes.",
    "expressions": [
      ".metadata.annotations.\"example.io/creatorId\""
    ],
    "data": [
      {
        "input": {
          "metadata": {
            "annotations": {
              "example.io/status": "Active",
              "example.io/creatorId": "fgs-dfg-879",
              "example.io/projectId": "879-dfgds-098"
            }
          }
        },
        "output": "fgs-dfg-879"
      }
    ],
    "identifier": 70333330
  },
  {
    "context": [
      "I\u2019d like to convert below file into a csv file, I think `jq` would be the suitable tool for it.",
      "The jq command for converting to CSV would then be along the lines of:",
      "jq -r '.[] | @csv' input.json"
    ],
    "utterance": "Convert an array of arrays, where each inner array represents a row, into lines of comma-separated values.",
    "expressions": [
      ".[] | @csv"
    ],
    "data": [
      {
        "input": [
          [
            "123456789012",
            "071395e8xxxxxxxx",
            "bad",
            "failed"
          ],
          [
            "098765432123",
            "094e9c34d3xxxxxxxx",
            "good",
            "successful"
          ]
        ],
        "output": [
          "\"123456789012\",\"071395e8xxxxxxxx\",\"bad\",\"failed\"",
          "\"098765432123\",\"094e9c34d3xxxxxxxx\",\"good\",\"successful\""
        ]
      }
    ],
    "identifier": 70346164
  },
  {
    "context": [
      "I would like to filter objects with a `.name` containing \"example\" and reduce the `.amount` property.",
      "echo \"$json\" | jq 'map(select(.name | contains(\"example\")) | .amount) | add'",
      "add(.[] | select(.name | contains(\"example\")) | .amount)"
    ],
    "utterance": "Sum the amount properties of all objects whose name contains \"example\".",
    "expressions": [
      "map(select(.name | contains(\"example\")) | .amount) | add",
      "reduce .[] as $x (0; if $x.name | contains(\"example\") then . + $x.amount else . end)",
      "def add(s): reduce s as $x (null; . + $x); add(.[] | select(.name | contains(\"example\")) | .amount)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "example-1",
            "amount": 4
          },
          {
            "name": "foo",
            "amount": 42
          },
          {
            "name": "example-2",
            "amount": 6
          }
        ],
        "output": 10
      }
    ],
    "identifier": 70342099
  },
  {
    "context": [
      "Given this:\n```json\n[\n  {\n    \"A\": \"a\",\n    \"B\": \"b\",\n    \"C\": \"c\"\n  },\n  {\n    \"D\": \"d\",\n    \"E\": \"e\"\n  }\n]\n```",
      "I want this:\n```json\n[\n { index: 0, key: \"A\", value: \"a\" },\n { index: 0, key: \"B\", value: \"b\" },\n { index: 0, key: \"C\", value: \"c\" },\n { index: 1, key: \"D\", value: \"d\" },\n { index: 1, key: \"E\", value: \"e\" }\n]\n```",
      "What I'm really looking for is to **transform** those elements in the input array into key-value pairs, and **add the index** of that element from the array.",
      "This gives expected result :\n\n```\njq 'to_entries|map({index:.key}+(.value|to_entries[]))' sample.json\n```"
    ],
    "utterance": "Transform each object in an array into key-value pairs, including the index of the object in the array as an 'index' property.",
    "expressions": [
      "to_entries|map({index:.key}+(.value|to_entries[]))"
    ],
    "data": [
      {
        "input": [
          {
            "A": "a",
            "B": "b",
            "C": "c"
          },
          {
            "D": "d",
            "E": "e"
          }
        ],
        "output": [
          {
            "index": 0,
            "key": "A",
            "value": "a"
          },
          {
            "index": 0,
            "key": "B",
            "value": "b"
          },
          {
            "index": 0,
            "key": "C",
            "value": "c"
          },
          {
            "index": 1,
            "key": "D",
            "value": "d"
          },
          {
            "index": 1,
            "key": "E",
            "value": "e"
          }
        ]
      }
    ],
    "identifier": 70341928
  },
  {
    "context": [
      "I want to add new field and output should look like",
      "{\n  \"no\": 1,\n  \"plant_number\": \"1050-0\",\n  \"1050-0\":\"1.1.1.1\"\n}",
      "declare -a ips=('1.1.1.1' '2.2.2.2' '3.3.3.3');",
      "jq --arg ips \"${ips[*]}\" '[.cubes, $ips / \" \"] | transpose[] as [$c,$ip] | $c + {($c.plant_number): $ip}' my.json"
    ],
    "utterance": "Add a new field to each object using the value of plant_number as the key and assign to it the corresponding IP address from a bash array.",
    "expressions": [
      "[.cubes, $ips / \" \"] | transpose[] as [$c,$ip] | $c + {($c.plant_number): $ip}"
    ],
    "data": [
      {
        "input": {
          "cubes": [
            {
              "no": 1,
              "plant_number": "1050-0"
            },
            {
              "no": 2,
              "plant_number": "2050-0"
            },
            {
              "no": 3,
              "plant_number": "3050-0"
            }
          ]
        },
        "output": [
          {
            "no": 1,
            "plant_number": "1050-0",
            "1050-0": "1.1.1.1"
          },
          {
            "no": 2,
            "plant_number": "2050-0",
            "2050-0": "2.2.2.2"
          },
          {
            "no": 3,
            "plant_number": "3050-0",
            "3050-0": "3.3.3.3"
          }
        ]
      }
    ],
    "identifier": 70349634
  },
  {
    "context": [
      "I need to reformat the Popeye Kubernetes report in a spreadsheet.",
      "The best format to export to csv would be something like :\n{\n  \"sanitizer\" : \"cluster\",\n  \"kube-object\" : \"Version\",\n  \"group\": \"__root__\",\n  \"level\": 0,\n  \"message\": \"[POP-406] K8s version OK\"\n}",
      "[\"sanitizer\", \"kube-object\", \"group\", \"level\", \"message\"],\n(.popeye.sanitizers[] | [.sanitizer] + (\n  .issues | to_entries[] | [.key, (.value[] | .group, .level, .message)])\n)\n| @csv",
      "jq -r '.[].sanitizers | map({sanitizer}+{\"kube-object\" : \"Version\"}+.issues.Version[])[]'"
    ],
    "utterance": "Extract sanitizer, kube-object, group, level, and message fields for each issue in the Popeye report in a tabular form suitable for spreadsheets.",
    "expressions": [
      "[\"sanitizer\", \"kube-object\", \"group\", \"level\", \"message\"],\n(.popeye.sanitizers[] | [.sanitizer] + (\n  .issues | to_entries[] | [.key, (.value[] | .group, .level, .message)])\n)\n| @csv",
      ".popeye.sanitizers | map({sanitizer}+{\"kube-object\" : \"Version\"}+.issues.Version[])[]"
    ],
    "data": [
      {
        "input": {
          "popeye": {
            "score": 90,
            "grade": "A",
            "sanitizers": [
              {
                "sanitizer": "cluster",
                "tally": {
                  "ok": 1,
                  "info": 0,
                  "warning": 0,
                  "error": 0,
                  "score": 100
                },
                "issues": {
                  "Version": [
                    {
                      "group": "__root__",
                      "level": 0,
                      "message": "[POP-406] K8s version OK"
                    }
                  ]
                }
              }
            ]
          }
        },
        "output": [
          {
            "sanitizer": "cluster",
            "kube-object": "Version",
            "group": "__root__",
            "level": 0,
            "message": "[POP-406] K8s version OK"
          }
        ]
      }
    ],
    "identifier": 70346247
  },
  {
    "context": [
      "Let's say I have the following JSON:",
      "I want to convert this into a more conventional comma-separated log format like:",
      "Can anyone assist with removing the keys here?",
      "With your very dubious JSON, the following produces the result you want except for the header:",
      "jq -r '[.Data[][]] | join(\",\")' weird.json",
      "If you want the result to be guaranteed to be CSV, then use `@csv` instead of `join`.  You might also wish to consider `@tsv`."
    ],
    "utterance": "Output an array of all nested VarCharValue fields at any depth as a single comma-separated line.",
    "expressions": [
      "[.Data[][]] | join(\",\")",
      "[.Data[][]] | @csv"
    ],
    "data": [
      {
        "input": {
          "Data": [
            [
              {
                "VarCharValue": "date"
              },
              {
                "VarCharValue": "time"
              }
            ],
            [
              {
                "VarCharValue": "12-13-2021"
              },
              {
                "VarCharValue": "23:22:33"
              }
            ]
          ]
        },
        "output": "date,time,12-13-2021,23:22:33"
      }
    ],
    "identifier": 70352555
  },
  {
    "context": [
      "I need an output similar to this:\n\n{\n  \"InstanceType\": \"c4.xlarge\",\n  \"PrivateIpAddress\": \"10.54.130.52\",\n  \"PlatformDetails\": \"Windows BYOL\",\n  \"State\":\n    \"Name\": \"running\"\n  }\n}",
      "aws ec2 describe-instances --instance-ids i-0079e143722b0b8f9 | jq -r '.Reservations[].Instances[] | {InstanceType, PrivateIpAddress, PlatformDetails, State} '\n{\n  \"InstanceType\": \"c4.xlarge\",\n  \"PrivateIpAddress\": \"10.54.130.52\",\n  \"PlatformDetails\": \"Windows BYOL\",\n  \"State\": {\n    \"Code\": 16,\n    \"Name\": \"running\"\n  }\n}",
      "This should work:\n     aws ec2 describe-instances --instance-ids i-0079e143722b0b8f9 | jq -r '.Reservations[].Instances[] | {InstanceType, PrivateIpAddress, PlatformDetails, State: {Name:.State.Name} }'"
    ],
    "utterance": "Extract InstanceType, PrivateIpAddress, PlatformDetails, and only the Name field from State for each instance.",
    "expressions": [
      ".Reservations[].Instances[] | {InstanceType, PrivateIpAddress, PlatformDetails, State: {Name: .State.Name}}"
    ],
    "data": [
      {
        "input": {
          "Reservations": [
            {
              "Instances": [
                {
                  "InstanceType": "c4.xlarge",
                  "PrivateIpAddress": "10.54.130.52",
                  "PlatformDetails": "Windows BYOL",
                  "State": {
                    "Code": 16,
                    "Name": "running"
                  }
                }
              ]
            }
          ]
        },
        "output": {
          "InstanceType": "c4.xlarge",
          "PrivateIpAddress": "10.54.130.52",
          "PlatformDetails": "Windows BYOL",
          "State": {
            "Name": "running"
          }
        }
      }
    ],
    "identifier": 70349769
  },
  {
    "context": [
      "jq --arg VERSION v0.10.0-rc.4 -r '.[] | select(.name==$VERSION) | .assets[] | select(.name |test(\"\\.sha256$\")) | .browser_download_url'",
      "jq --arg VERSION v0.10.0-rc.4 -r '.[] | select(.name==$VERSION) | .assets[]  | select(.content_type ==\"application/zip\") | .name'"
    ],
    "utterance": "Extract the download URL for a .sha256 asset and the name of the .zip asset from the release where name equals v0.10.0-rc.4 and asset content_type equals application/zip.",
    "expressions": [
      ".[] | select(.name==$VERSION) | .assets[] | select(.name |test(\"\\.sha256$\")) | .browser_download_url",
      ".[] | select(.name==$VERSION) | .assets[]  | select(.content_type ==\"application/zip\") | .name"
    ],
    "identifier": 70352938
  },
  {
    "context": [
      "I need that the curl command returns to me three params: 1. the \"name\" (which is in the json response), 2. the http code and 3. the time response.",
      "curl -X \"GET\" -w '{\"code\": \"%{http_code}\", \"time\": \"%{time_total}\"}' \"https://my-api-url-here&compress=true\" |\n  jq -sr '.[0].Items[] | .descs.por.name, .[1].code, .[1].time'"
    ],
    "utterance": "Extract the value of descs.por.name from the first element and the values of code and time from the second element when parsing an array of two JSON objects.",
    "expressions": [
      ".[0].Items[] | .descs.por.name, .[1].code, .[1].time"
    ],
    "data": [
      {
        "input": [
          {
            "Result": 0,
            "ExecutionTime": 0,
            "Items": [
              {
                "item1": "x",
                "item2": "x",
                "item3": "x",
                "item4": "x",
                "genre1": "x",
                "genre2": "x",
                "item5": "x",
                "item6": "x",
                "descs": {
                  "por": {
                    "name": "santa-claus",
                    "item7": "xxxx"
                  }
                }
              }
            ]
          },
          {
            "code": "200",
            "time": "0.347"
          }
        ],
        "output": [
          "santa-claus",
          "200",
          "0.347"
        ]
      }
    ],
    "identifier": 70352487
  },
  {
    "context": [
      "for i in $(curl --silent -s -u \"$USERNAME:$GITHUB_TOKEN\" \"${API_URL_PREFIX}/orgs/$ORG/teams/${TEAM_ID}/repos?page=${PAGE}&per_page=100\" | jq -M -r 'sort_by(.name) | .[] | .name');",
      "jq: error (at <stdin>:4): Cannot index string with string \"name\"",
      "It means it can not find the key. Check that your `query` matches the structure of the `json` document."
    ],
    "utterance": "Extract the name field from each array element, ensuring that the input is an array of objects containing the name key.",
    "expressions": [
      ".[] | .name",
      "sort_by(.name) | .[] | .name"
    ],
    "identifier": 70361486
  },
  {
    "context": [
      "Is there a way to find the location, and values, of specific objects in heavily-nested JSON files, using jq?",
      "I never know where they are going to occur in the structure of the JSON, and I never know the names of the parents. I just know the name of the object I'm searching for.",
      "For example, I'm trying to find where the \"FIND_ME\" objects are in the following JSON, in relation to the JSON structure as a whole, but also the values contained in \"FIND_ME\".",
      "I'd ideally get the following output:",
      "{\n    \"system\": {\n        \"operating_system_1\": {\n            \"FIND_ME\": {\n                \"special_detail_1\": \"some_detail\",\n                \"special_detail_2\": \"some_detail\"\n            }\n        },\n        \"operating_system_2\": {\n            \"feature_1\": {\n                \"FIND_ME\": {\n                    \"special_detail_3\": \"some_detail\",\n                    \"special_detail_4\": \"some_detail\"\n                }\n            }\n        }\n    }\n}",
      "cat json_file | jq '..|.FIND_ME? | select(. != null)'",
      "Which gives the values of \"FIND_ME\", like this",
      "{\n  \"special_detail_1\": \"some_detail\",\n  \"special_detail_2\": \"some_detail\"\n}",
      "{\n  \"special_detail_3\": \"some_detail\",\n  \"special_detail_4\": \"some_detail\"\n}",
      "but it doesn't display the parent structure.",
      "Try\n```sh\njq --arg query \"FIND_ME\" '\n  reduce ((paths | select(.[-1] == $query)) as $p | [$p, getpath($p)])\n    as $f ({}; setpath($f[0]; $f[1]))\n' json_file\n```"
    ],
    "utterance": "Extract all objects with the key 'FIND_ME', preserving the structure above each occurrence.",
    "expressions": [
      "jq --arg query \"FIND_ME\" '\n  reduce ((paths | select(.[-1] == $query)) as $p | [$p, getpath($p)])\n    as $f ({}; setpath($f[0]; $f[1]))\n' json_file"
    ],
    "data": [
      {
        "input": {
          "system": {
            "operating_system_1": {
              "FIND_ME": {
                "special_detail_1": "some_detail",
                "special_detail_2": "some_detail"
              },
              "feature_1": {
                "detail_1": "some_detail"
              },
              "feature_2": {
                "detail_2": "some_detail"
              }
            },
            "operating_system_2": {
              "feature_1": {
                "FIND_ME": {
                  "special_detail_3": "some_detail",
                  "special_detail_4": "some_detail"
                },
                "detail_3": "some_detail"
              },
              "feature_2": {
                "detail_4": "some_detail"
              }
            },
            "operating_system_3": {
              "feature_1": {
                "detail_5": "some_detail"
              },
              "feature_2": {
                "detail_6": "some_detail"
              }
            }
          }
        },
        "output": {
          "system": {
            "operating_system_1": {
              "FIND_ME": {
                "special_detail_1": "some_detail",
                "special_detail_2": "some_detail"
              }
            },
            "operating_system_2": {
              "feature_1": {
                "FIND_ME": {
                  "special_detail_3": "some_detail",
                  "special_detail_4": "some_detail"
                }
              }
            }
          }
        }
      }
    ],
    "identifier": 70278944
  },
  {
    "identifier": 70390063
  },
  {
    "context": [
      "What I'd like to achieve is to loop through each values and pass the findingId & products as arguments in a bash script.",
      "Would result in:",
      "./somescript.sh someFindingID#84209 hostA.corp.somedomain.org",
      "./somescript.sh someFindingID#84209 hostB.corp.somedomain.org",
      "...",
      "jq -r '.data[]\n| .. \n| objects\n| select(has(\"findingId\"))\n| \"./somescript.sh \\\"\\(.findingId)\\\" \" + .products[]\n'",
      "jq -r '\n   .data[][][] |\n   .products[] as $product |\n   @sh \"./somescript.sh \\( .findingId ) \\( $product )\"\n'"
    ],
    "utterance": "For each findingId and its associated product, generate a shell command line containing the findingId and product as separate arguments.",
    "expressions": [
      ".data.activeFindings.findings[] | .products[] as $product | @sh \"./somescript.sh \\(.findingId) \\($product)\"",
      ".data[][][] | .products[] as $product | @sh \"./somescript.sh \\(.findingId) \\($product)\"",
      ".data[] | .. | objects | select(has(\"findingId\")) | \"./somescript.sh \\(.findingId) \" + .products[]"
    ],
    "data": [
      {
        "input": {
          "data": {
            "activeFindings": {
              "findings": [
                {
                  "findingId": "someFindingID#84209",
                  "products": [
                    "hostA.corp.somedomain.org",
                    "hostB.corp.somedomain.org"
                  ],
                  "totalAffectedObjectsCount": 6
                },
                {
                  "findingId": "someFindingID#2145016",
                  "products": [
                    "hostC.corp.somedomain.org"
                  ],
                  "totalAffectedObjectsCount": 1
                },
                {
                  "findingId": "someFindingID#67129",
                  "products": [
                    "hostD.corp.somedomain.org"
                  ],
                  "totalAffectedObjectsCount": 4
                },
                {
                  "findingId": "someFindingID#67774",
                  "products": [
                    "hostA.corp.somedomain.org"
                  ],
                  "totalAffectedObjectsCount": 6
                }
              ]
            }
          }
        },
        "output": [
          "./somescript.sh someFindingID#84209 hostA.corp.somedomain.org",
          "./somescript.sh someFindingID#84209 hostB.corp.somedomain.org",
          "./somescript.sh someFindingID#2145016 hostC.corp.somedomain.org",
          "./somescript.sh someFindingID#67129 hostD.corp.somedomain.org",
          "./somescript.sh someFindingID#67774 hostA.corp.somedomain.org"
        ]
      }
    ],
    "identifier": 70353107
  },
  {
    "context": [
      "I have the following json and want to remove multiple entries from the ebooks array if they are not in the following array [\"Pascal\", \"Python\"] (will eventually be dynamic array, this is just for example)",
      "was hoping to do something like this, which if it worked would delete last one containing the SQL because it's not in the array",
      "Use `del`, `IN` and a capital `B` in `eBooks` :)",
      "jq '.eBooks |= map(select(.language | IN(\"Pascal\", \"Python\")))' ebooks.json"
    ],
    "utterance": "Keep only entries in the eBooks array where the language is either 'Pascal' or 'Python'.",
    "expressions": [
      ".eBooks |= map(select(.language | IN(\"Pascal\", \"Python\")))"
    ],
    "data": [
      {
        "input": {
          "eBooks": [
            {
              "language": "Pascal",
              "edition": "third"
            },
            {
              "language": "Python",
              "edition": "four"
            },
            {
              "language": "SQL",
              "edition": "second"
            }
          ]
        },
        "output": {
          "eBooks": [
            {
              "language": "Pascal",
              "edition": "third"
            },
            {
              "language": "Python",
              "edition": "four"
            }
          ]
        }
      }
    ],
    "identifier": 70381928
  },
  {
    "context": [
      "I have two JSON objects in two files (result_0.json and result_1.json) which look like this ...",
      "What I would like to get looks like this: ...",
      "jq -s add result_0.json result_1.json but it just overwrites the values in result_0.json with the values of result_1.json.",
      "If `.data` and `.pool` are the only keys in the json files, you can use",
      "jq -n '{ data: { pools: [inputs.data.pools] | add } }' result0 result1",
      "This will create the desired output: ..."
    ],
    "utterance": "Combine the pools arrays from the data objects of two input objects into a single pools array within one object.",
    "expressions": [
      "jq -n '{ data: { pools: [inputs.data.pools] | add } }' result_0.json result_1.json"
    ],
    "data": [
      {
        "input": [
          {
            "data": {
              "pools": [
                {
                  "id": "1"
                },
                {
                  "id": "2"
                }
              ]
            }
          },
          {
            "data": {
              "pools": [
                {
                  "id": "3"
                },
                {
                  "id": "4"
                }
              ]
            }
          }
        ],
        "output": {
          "data": {
            "pools": [
              {
                "id": "1"
              },
              {
                "id": "2"
              },
              {
                "id": "3"
              },
              {
                "id": "4"
              }
            ]
          }
        }
      }
    ],
    "identifier": 70365491
  },
  {
    "context": [
      "I want to update the array with below json:\r\n\r\n`{ \"name\" : santa\", \"class\" : \"christmas\" }`",
      "and the output should be:\r\n\r\n`[\r\n   { \"name\" : Jon\", \"class\" : \"senior\" }, \r\n   { \"name\" : santa\", \"class\" : \"christmas\" }\r\n]`",
      "Generally, this should work (but still needs improvement on certain levels):\n```sh\nJSON='[{\"name\": \"Jon\", \"class\": \"senior\"}]'\necho \"$JSON\" | jq '. += [{\"new_key\": \"new_value\"}]'\n```",
      "here is how you do it without piping the source JSON array:\n\n```sh\nJSON='[{\"name\": \"Jon\", \"class\": \"senior\"}]'\njq --null-input --argjson  a \"$JSON\" '$a  + [{\"name\" : \"santa\", \"class\" : \"christmas\" }]'\n```"
    ],
    "utterance": "Append {\"name\": \"santa\", \"class\": \"christmas\"} as a new element to the existing array.",
    "expressions": [
      ". += [{\"name\": \"santa\", \"class\": \"christmas\"}]",
      "$a + [{\"name\": \"santa\", \"class\": \"christmas\"}]"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Jon",
            "class": "senior"
          }
        ],
        "output": [
          {
            "name": "Jon",
            "class": "senior"
          },
          {
            "name": "santa",
            "class": "christmas"
          }
        ]
      }
    ],
    "identifier": 70361958
  },
  {
    "context": [
      "So, I want to select HTTP ports of each ip, and output in that format:",
      "1.11.11.111:888",
      "2.22.22.222:4444",
      "2.22.22.222:8085",
      "Try",
      "jq -r '.[] | .ip + \":\\(.services[] | select(.service_name == \"HTTP\") | .port)'",
      "1.11.11.111:888",
      "2.22.22.222:4444",
      "2.22.22.222:8085"
    ],
    "utterance": "For each element, select the services with service_name equal to HTTP and output the ip and port in the format ip:port.",
    "expressions": [
      ".[] | .ip + \":\\(.services[] | select(.service_name == \"HTTP\") | .port)"
    ],
    "data": [
      {
        "input": [
          {
            "ip": "1.11.11.111",
            "services": [
              {
                "port": 22,
                "service_name": "SSH",
                "transport_protocol": "TCP"
              },
              {
                "port": 888,
                "service_name": "HTTP",
                "transport_protocol": "TCP"
              },
              {
                "port": 999,
                "service_name": "FTP",
                "transport_protocol": "TCP"
              },
              {
                "port": 17000,
                "service_name": "UNKNOWN",
                "transport_protocol": "TCP"
              }
            ],
            "location": {
              "continent": "Europe",
              "country": "France",
              "country_code": "FR",
              "city": "Cagnes-sur-Mer",
              "postal_code": "06800",
              "timezone": "Europe/Paris",
              "province": "Provence-Alpes-C\u00f4te d'Azur",
              "coordinates": {
                "latitude": 43.6627,
                "longitude": 7.1545
              },
              "registered_country": "France",
              "registered_country_code": "FR"
            },
            "autonomous_system": {
              "asn": 3215,
              "description": "France Telecom - Orange",
              "bgp_prefix": "2.15.0.0/16",
              "name": "France Telecom - Orange",
              "country_code": "FR"
            },
            "operating_system": {
              "uniform_resource_identifier": "cpe:2.3:o:*:linux:*:*:*:*:*:*:*:*",
              "part": "o",
              "product": "linux",
              "source": "OSI_TRANSPORT_LAYER"
            }
          },
          {
            "ip": "2.22.22.222",
            "services": [
              {
                "port": 4444,
                "service_name": "HTTP",
                "transport_protocol": "TCP"
              },
              {
                "port": 8085,
                "service_name": "HTTP",
                "transport_protocol": "TCP"
              }
            ],
            "location": {
              "continent": "Europe",
              "country": "United Kingdom",
              "country_code": "GB",
              "city": "Scunthorpe",
              "postal_code": "DN16",
              "timezone": "Europe/London",
              "province": "England",
              "coordinates": {
                "latitude": 53.5651,
                "longitude": -0.6375
              },
              "registered_country": "United Kingdom",
              "registered_country_code": "GB"
            },
            "autonomous_system": {
              "asn": 12576,
              "description": "EE Ltd",
              "bgp_prefix": "2.25.0.0/16",
              "name": "EE Ltd",
              "country_code": "GB"
            }
          }
        ],
        "output": [
          "1.11.11.111:888",
          "2.22.22.222:4444",
          "2.22.22.222:8085"
        ]
      }
    ],
    "identifier": 70356481
  },
  {
    "context": [
      "I\u2019m parsing through the IP address and a tag called \"Enviroment\". The enviroment tag in the instance does not exist therefore it does not throw me any result.",
      "How do I show the IP address in the output of the command even if the enviroment tag does not exist?",
      "You can either use an `if ... then ... else ... end` construct, or `//`. For example:",
      ".Reservations[].Instances[] | {IP: .PrivateIpAddress} +   ({Ambiente: (.Tags[]|select(.Key==\"Environment\")|.Value)} // null)",
      "This format is _perfect_ for [`from_entries`][1], which can transform this list of tags into a convenient mapping object. Try this:",
      ".Reservations[].Instances[] | { IP: .PrivateIpAddress, Ambiente: (.Tags|from_entries.Environment) }",
      "{ \"IP\":\"10.0.0.1\",\"Ambiente\":\"alpha\" }",
      "{ \"IP\":\"10.0.0.2\",\"Ambiente\":null }"
    ],
    "utterance": "For each instance, output its PrivateIpAddress and the value of its Environment tag as Ambiente, showing null for Ambiente if the Environment tag is absent.",
    "expressions": [
      ".Reservations[].Instances[] | {IP: .PrivateIpAddress} + ({Ambiente: (.Tags[]|select(.Key==\"Environment\")|.Value)} // null)",
      ".Reservations[].Instances[] | { IP: .PrivateIpAddress, Ambiente: (.Tags|from_entries.Environment) }"
    ],
    "data": [
      {
        "input": {
          "Reservations": [
            {
              "Instances": [
                {
                  "PrivateIpAddress": "10.0.0.1",
                  "Tags": [
                    {
                      "Key": "Name",
                      "Value": "Balance-OTA-SS_a"
                    },
                    {
                      "Key": "Environment",
                      "Value": "alpha"
                    }
                  ]
                }
              ]
            },
            {
              "Instances": [
                {
                  "PrivateIpAddress": "10.0.0.2",
                  "Tags": [
                    {
                      "Key": "Name",
                      "Value": "Balance-OTA-SS_a"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          {
            "IP": "10.0.0.1",
            "Ambiente": "alpha"
          },
          {
            "IP": "10.0.0.2",
            "Ambiente": null
          }
        ]
      }
    ],
    "identifier": 70369094
  },
  {
    "context": [
      "I want to get names where type is A.",
      "wouldn't simply `... | select(.type == \"A\")` do the trick?",
      "... | jq '.rrsets[] | select(.type == \"A\")'",
      "And then just get the `.name` if you want only that (using `-r` to get rid of the JSON formatting):",
      "... | jq -r '.rrsets[] | select(.type == \"A\").name'",
      "name1."
    ],
    "utterance": "List the name values for all objects with type equal to A.",
    "expressions": [
      ".rrsets[] | select(.type == \"A\").name",
      ".rrsets[] | select(.type == \"A\") | .name"
    ],
    "data": [
      {
        "input": {
          "rrsets": [
            {
              "comments": [],
              "name": "name1.",
              "records": [
                {
                  "content": "10.10.10.10",
                  "disabled": false
                }
              ],
              "ttl": 60,
              "type": "A"
            },
            {
              "comments": [],
              "name": "name2.",
              "records": [
                {
                  "content": "20.20.20.20",
                  "disabled": false
                }
              ],
              "ttl": 60,
              "type": "CNAME"
            }
          ]
        },
        "output": "name1."
      }
    ],
    "identifier": 70391566
  },
  {
    "context": [
      "\"I wanted to take the \\\"ids\\\" from all price object and put into an array variable.\"",
      "\"I am using the below query but the result is coming in the proper way. \\n\\n`priceIds=$(jq -r .fullCharges[].price.id ${file})`\\n\\nUsing above command, it is behaving like a single value, not like array. If I print the priceId value it is only showing the last value.\"",
      "\"1. Using extra parens, it helped me to create array.\""
    ],
    "utterance": "Extract the id values from all price objects under fullCharges and output them as an array of strings.",
    "expressions": [
      ".fullCharges[].price.id",
      "[.fullCharges[].price.id]"
    ],
    "data": [
      {
        "input": {
          "documentType": "Prices",
          "fullCharges": [
            {
              "ResourceId": null,
              "price": {
                "href": null,
                "id": "8ddaaabc92bc"
              },
              "product": {
                "href": null,
                "id": "123"
              }
            },
            {
              "price": {
                "href": null,
                "id": "326f0f273258"
              },
              "product": {
                "href": null,
                "id": "123"
              }
            }
          ],
          "createdBy": "test",
          "createdOn": "2021-10-05T00:00:55Z",
          "currentSeqNum": 2
        },
        "output": [
          "8ddaaabc92bc",
          "326f0f273258"
        ]
      }
    ],
    "identifier": 70392901
  },
  {
    "context": [
      "I wanted the values of $arch and $ram to be updated.",
      "jq -n --arg arch \"$arch\" --arg ram \"$ram\" '{\"System Arch\":{\"Arch\":$arch,\"RAM\":$ram}}'",
      "jq -n '{\"System Arch\":{\"Arch\":env.arch,\"RAM\":env.ram}}'"
    ],
    "utterance": "Create an object with keys 'Arch' and 'RAM' set to the values of the variables arch and ram.",
    "expressions": [
      "jq -n --arg arch \"$arch\" --arg ram \"$ram\" '{\"System Arch\":{\"Arch\":$arch,\"RAM\":$ram}}'",
      "jq -n '{\"System Arch\":{\"Arch\":env.arch,\"RAM\":env.ram}}'"
    ],
    "identifier": 70405520
  },
  {
    "context": [
      "I have json file like this \r\n```\r\n{\r\n  &quot;version&quot;: &quot;4.6.0&quot;,\r\n  &quot;flags&quot;: {\r\n    &quot;T1&quot;: true,\r\n    &quot;T1c&quot;: false,\r\n    &quot;T2&quot;: false,\r\n    &quot;FLAIR&quot;: false\r\n  },\r\n  &quot;shapes&quot;: [],\r\n  &quot;imagePath&quot;: &quot;HC-002_LM-0000_aparc+aseg_1mm_bin.png&quot;,\r\n  &quot;imageData&quot;:xxxxxxxxx\r\n}\r\n```",
      "and I need the output to be \r\n```\r\nT1\r\n```\r\nas the value is true, Please suggest correct use of jq here, thanks!",
      "Use `to_entries` to access field name and value of an object&#39;s items and `select` those you need:\r\n```sh\r\njq --raw-output &#39;.flags | to_entries[] | select(.value).key&#39; \r\n```\r\n```\r\nT1\r\n```\r\n[Demo](https://jqplay.org/s/wdfq4ZyO5X)"
    ],
    "utterance": "Return the key within the 'flags' object whose value is true.",
    "expressions": [
      ".flags | to_entries[] | select(.value).key"
    ],
    "data": [
      {
        "input": {
          "version": "4.6.0",
          "flags": {
            "T1": true,
            "T1c": false,
            "T2": false,
            "FLAIR": false
          },
          "shapes": [],
          "imagePath": "HC-002_LM-0000_aparc+aseg_1mm_bin.png",
          "imageData": "xxxxxxxxx"
        },
        "output": "T1"
      }
    ],
    "identifier": 70393010
  },
  {
    "context": [
      "question 2) I want want to count name == foo, the result should be `2`",
      "The number of documents whose root object have value `foo` for key `name`:",
      "jq -sr 'map( select( .name == \"foo\" ) ) | length'",
      "jq -nr '[ inputs | select( .name == \"foo\" ) ] | length'",
      "Similarly, instead of\n\n     jq -nr '[ inputs | select( .name == \"foo\" ) ] | length'\n\nyou would use the same \"def\" with:\n\n    count(inputs | select( .name == \"foo\" ))"
    ],
    "utterance": "Count the number of objects where the name key has the value foo.",
    "expressions": [
      "map(select(.name == \"foo\")) | length",
      "[inputs | select(.name == \"foo\")] | length",
      "count(inputs | select(.name == \"foo\"))"
    ],
    "data": [
      {
        "input": [
          {
            "name": "foo",
            "title": "b"
          },
          {
            "name": "foo",
            "title": "c"
          },
          {
            "name": "go",
            "title": "d"
          }
        ],
        "output": 2
      }
    ],
    "identifier": 70417861
  },
  {
    "context": [
      "I am trying to select all elements that have a label of is-secret=true",
      "Output needs to be an array.",
      "jq 'map(select(.labels[\"is-secret\"] == \"true\"))'",
      "jq 'map(select(.labels.\"is-secret\" == \"true\"))'"
    ],
    "utterance": "Filter all objects where the attribute 'is-secret' inside 'labels' is equal to 'true', returning the results as an array.",
    "expressions": [
      "map(select(.labels[\"is-secret\"] == \"true\"))",
      "map(select(.labels.\"is-secret\" == \"true\"))"
    ],
    "data": [
      {
        "input": [
          {
            "createTime": "2021-12-15T09:39:59.812377Z",
            "etag": "\"15d377a6a77bab\"",
            "labels": {
              "is-secret": "false"
            },
            "name": "projects/xxx/secrets/xxx",
            "replication": {
              "automatic": {}
            }
          },
          {
            "createTime": "2021-12-19T03:47:53.594568Z",
            "etag": "\"15d377a868c624\"",
            "labels": {
              "is-secret": "true"
            },
            "name": "projects/xxx/secrets/xxx",
            "replication": {
              "automatic": {}
            }
          }
        ],
        "output": [
          {
            "createTime": "2021-12-19T03:47:53.594568Z",
            "etag": "\"15d377a868c624\"",
            "labels": {
              "is-secret": "true"
            },
            "name": "projects/xxx/secrets/xxx",
            "replication": {
              "automatic": {}
            }
          }
        ]
      }
    ],
    "identifier": 70409053
  },
  {
    "context": [
      "I would like use `jq` for divide a large array into 6 parts.",
      "[_nwise(length / 6 | ceil)]",
      "[_nwise(length / 6|ceil) ]+[range(0;6-length)|[]]"
    ],
    "utterance": "Split an array into 6 parts, evenly distributing the elements, padding with empty arrays if necessary.",
    "expressions": [
      "[_nwise(length / 6 | ceil)]",
      "[_nwise(length / 6|ceil) ]+[range(0;6-length)|[]]"
    ],
    "identifier": 70447886
  },
  {
    "context": [
      "The JSON files look like:",
      "{\r\n  \"name\": \"My Collection\",\r\n  \"description\": \"This is a great collection.\",\r\n  \"date\": 1639717379161,\r\n  \"attributes\": [\r\n    {\r\n      \"trait_type\": \"Background\",\r\n      \"value\": \"Sand\"\r\n    },\r\n    {\r\n      \"trait_type\": \"Skin\",\r\n      \"value\": \"Dark Brown\"\r\n    },\r\n    {\r\n      \"trait_type\": \"Mouth\",\r\n      \"value\": \"Smile Basic\"\r\n    },\r\n    {\r\n      \"trait_type\": \"Eyes\",\r\n      \"value\": \"Confused\"\r\n    }\r\n  ]  \r\n}",
      "playing around with these, I was able to get\n```bash\njq -r '[.name, .description, .date, (.attributes | [.[] | .trait_type] | @csv | gsub(\",\";\";\") | gsub(\"\\\"\";\"\")), (.attributes | [.[] | .value] | @csv | gsub(\",\";\";\") | gsub(\"\\\"\";\"\"))] | @csv'\n```",
      "to give us:  \n\"My Collection\",\"This is a great collection.\",1639717379161,\"Background;Skin;Mouth;Eyes\",\"Sand;Dark Brown;Smile Basic;Confused\""
    ],
    "utterance": "Convert an object containing name, description, date, and an array of attribute objects into a CSV line where attributes' trait_type and value fields are each combined into semicolon-separated values.",
    "expressions": [
      "[.name, .description, .date, (.attributes | [.[] | .trait_type] | @csv | gsub(\",\";\";\") | gsub(\"\\\"\";\"\")), (.attributes | [.[] | .value] | @csv | gsub(\",\";\";\") | gsub(\"\\\"\";\"\"))] | @csv"
    ],
    "data": [
      {
        "input": {
          "name": "My Collection",
          "description": "This is a great collection.",
          "date": 1639717379161,
          "attributes": [
            {
              "trait_type": "Background",
              "value": "Sand"
            },
            {
              "trait_type": "Skin",
              "value": "Dark Brown"
            },
            {
              "trait_type": "Mouth",
              "value": "Smile Basic"
            },
            {
              "trait_type": "Eyes",
              "value": "Confused"
            }
          ]
        },
        "output": "\"My Collection\",\"This is a great collection.\",1639717379161,\"Background;Skin;Mouth;Eyes\",\"Sand;Dark Brown;Smile Basic;Confused\""
      }
    ],
    "identifier": 70396812
  },
  {
    "context": [
      "The issue I am facing is that I have select by the value of a property, rather than by a numeric array index",
      "What i am trying to do is merge it under \"accounts\" and under \"name\": \"Retrieves the collection of Account resources.\"",
      "jq -s '\n   .[0].event += .[1].item |\n   map(select(.name==\"accounts\")) |\n   .[].item\n' jqtest.json collection.json",
      "Fixed:\n\n```sh\njq -s '\n    ( .[1].item[] | select( .name == \"accounts\" ) | .item[] ) += .[0] | .[1]\n' jqtest.json collection.json\n```",
      "I find the following clearer (less mental overhead):\n\n```sh\njq -s '\n   .[0] as $to_insert |\n   .[1] | ( .item[] | select( .name == \"accounts\" ) | .item[] ) += $to_insert\n' jqtest.json collection.json\n```",
      "That said, I would avoid slurping in favour of `--argfile`.\n\n```sh\njq --argfile to_insert jqtest.json '\n    ( .item[] | select( .name == \"accounts\" ) | .item[] ) += $to_insert\n' collection.json\n```"
    ],
    "utterance": "Merge the 'event' array from one file into the object with name 'Retrieves the collection of Account resources.' nested under 'accounts' in another file.",
    "expressions": [
      "jq -s '(. [1].item[] | select(.name == \"accounts\") | .item[] ) += .[0] | .[1]' jqtest.json collection.json",
      "jq -s '.[0] as $to_insert | .[1] | (.item[] | select(.name == \"accounts\") | .item[] ) += $to_insert' jqtest.json collection.json",
      "jq --argfile to_insert jqtest.json '(.item[] | select(.name == \"accounts\") | .item[] ) += $to_insert' collection.json"
    ],
    "data": [
      {
        "input": {
          "jqtest.json": {
            "event": [
              {
                "listen": "test",
                "script": {
                  "exec": [],
                  "type": "text/javascript"
                }
              }
            ]
          },
          "collection.json": {
            "item": [
              {
                "name": "accounts",
                "item": [
                  {
                    "name": "Retrieves the collection of Account resources."
                  }
                ]
              },
              {
                "name": "accounts mapped",
                "item": [
                  {
                    "name": "Retrieves the collection of AccountMapped resources."
                  }
                ]
              }
            ]
          }
        },
        "output": {
          "item": [
            {
              "name": "accounts",
              "item": [
                {
                  "name": "Retrieves the collection of Account resources.",
                  "event": [
                    {
                      "listen": "test",
                      "script": {
                        "exec": [],
                        "type": "text/javascript"
                      }
                    }
                  ]
                }
              ]
            },
            {
              "name": "accounts mapped",
              "item": [
                {
                  "name": "Retrieves the collection of AccountMapped resources."
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 70396171
  },
  {
    "context": [
      "Each address patient contains its patient id.",
      "`patients.json`:\r\n{\r\n  id: 1,\r\n  name: \"name1\"\r\n}\r\n{\r\n  id: 2,\r\n  name: \"name2\"\r\n}",
      "`patient_address.json`:\r\n{\r\n  patient_id: 1,\r\n  city: \"city1-1\",\r\n  town: \"town1-1\"\r\n}\r\n{\r\n  patient_id: 1,\r\n  city: \"city1-2\",\r\n  town: \"town1-2\"\r\n}\r\n{\r\n  patient_id: 2,\r\n  city: \"city2-1\",\r\n  town: \"town2-1\"\r\n}",
      "My desired result would be:\r\n{\r\n  id: 1,\r\n  name: \"name1\",\r\n  address: [\r\n  {\r\n    city: \"city1-1\",\r\n    town: \"town1-1\"\r\n  },\r\n  {\r\n    city: \"city1-2\",\r\n    town: \"town1-2\"\r\n  }]\r\n},\r\n{\r\n  id: 2,\r\n  name: \"name2\",\r\n  address: [\r\n  {\r\n    city: \"city2-1\",\r\n    town: \"town2-1\"\r\n  }]\r\n}",
      "you can use jq to produce the desired transformation as follows:",
      "< patients.json jq --slurpfile address patient_address.json '\r\n  (reduce $address[] as $a ({}; \r\n     .[ ($a.patient_id)|tostring].address += [$a | {city,town}] )) as $dict\r\n  | . + $dict[.id|tostring]  \r\n'",
      "Output:\r\n{\r\n  \"id\": 1,\r\n  \"name\": \"name1\",\r\n  \"address\": [\r\n    {\r\n      \"city\": \"city1-1\",\r\n      \"town\": \"town1-1\"\r\n    },\r\n    {\r\n      \"city\": \"city1-2\",\r\n      \"town\": \"town1-2\"\r\n    }\r\n  ]\r\n}\r\n{\r\n  \"id\": 2,\r\n  \"name\": \"name2\",\r\n  \"address\": [\r\n    {\r\n      \"city\": \"city2-1\",\r\n      \"town\": \"town2-1\"\r\n    }\r\n  ]\r\n} "
    ],
    "utterance": "For each patient, add an address field containing all addresses where patient_id matches the patient's id.",
    "expressions": [
      "(reduce $address[] as $a ({}; .[ ($a.patient_id)|tostring].address += [$a | {city,town}] )) as $dict | . + $dict[.id|tostring]"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "name": "name1"
          },
          {
            "id": 2,
            "name": "name2"
          }
        ],
        "output": [
          {
            "id": 1,
            "name": "name1",
            "address": [
              {
                "city": "city1-1",
                "town": "town1-1"
              },
              {
                "city": "city1-2",
                "town": "town1-2"
              }
            ]
          },
          {
            "id": 2,
            "name": "name2",
            "address": [
              {
                "city": "city2-1",
                "town": "town2-1"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 70419797
  },
  {
    "context": [
      "Here, jq is printing the instances only with tag Name, and other instances which don\u2019t have tag name are not printed.",
      "Expected Output:\r\n\r\n    master-bastion i-026b52da57ae3a85 t2.micro aus 10.90.0.68 52.62.76.17\r\n    i-06d669ba5cda0c4d t3.medium aus 10.90.100.142\r\n    i-062669ba5cda0sfs t3.medium aus 10.90.100.147\r\n...",
      "(.Tags[] | select(.Key == \"Name\")).value // \"\"",
      ".Tags | map({key: .Key, value: .Value}) | from_entries | .Name // \"\""
    ],
    "utterance": "Return all instances, displaying the Name tag if present or an empty string if missing, along with InstanceId, InstanceType, KeyName, PrivateIpAddress, and PublicIpAddress.",
    "expressions": [
      "(.Tags[] | select(.Key == \"Name\") | .Value) // \"\" + \" \" + .InstanceId + \" \" + .InstanceType + \" \" + .KeyName + \" \" + .PrivateIpAddress + \" \" + (.PublicIpAddress // \"\")",
      ".Tags | map({key: .Key, value: .Value}) | from_entries | .Name // \"\" + \" \" + .InstanceId + \" \" + .InstanceType + \" \" + .KeyName + \" \" + .PrivateIpAddress + \" \" + (.PublicIpAddress // \"\")"
    ],
    "identifier": 70445005
  },
  {
    "context": [
      "I have this json:\r\n\r\n```lang-json\r\n{\r\n  \"idTypes\":\"type1|type2|type3\",\r\n  \"idValues\":\"xxx|yyy|zzz\"\r\n}\r\n```",
      "I need to reshape this information to:\r\n\r\n```lang-json\r\n{\r\n  \"idType\": \"type1\",\r\n  \"idValue\": \"xxx\"\r\n}\r\n{\r\n  \"idType\": \"type2\",\r\n  \"idValue\": \"yyy\"\r\n}\r\n{\r\n  \"idType\": \"type3\",\r\n  \"idValue\": \"zzz\"\r\n}\r\n```",
      "to_entries | map(.value | split(\"|\")) | transpose[] | {\"idType\": .[0], \"idValue\": .[1] }",
      "Will generate\r\n```json\r\n{\r\n  \"idType\": \"type1\",\r\n  \"idValue\": \"xxx\"\r\n}\r\n{\r\n  \"idType\": \"type2\",\r\n  \"idValue\": \"yyy\"\r\n}\r\n{\r\n  \"idType\": \"type3\",\r\n  \"idValue\": \"zzz\"\r\n}\r\n```"
    ],
    "utterance": "Produce an object for each pair of corresponding entries where the first value is from splitting idTypes by '|' and the second value is from splitting idValues by '|', assigning to keys idType and idValue respectively.",
    "expressions": [
      "to_entries | map(.value | split(\"|\")) | transpose[] | {\"idType\": .[0], \"idValue\": .[1] }"
    ],
    "data": [
      {
        "input": {
          "idTypes": "type1|type2|type3",
          "idValues": "xxx|yyy|zzz"
        },
        "output": [
          {
            "idType": "type1",
            "idValue": "xxx"
          },
          {
            "idType": "type2",
            "idValue": "yyy"
          },
          {
            "idType": "type3",
            "idValue": "zzz"
          }
        ]
      }
    ],
    "identifier": 70421326
  },
  {
    "context": [
      "Using jq, I want to get a list of application names, all versions and server name. The list should not contain information about the latest version.",
      "Desired output:\n\"app_1,  0.0.1,  vm123-4.domain.com\"\n\"app_1,  0.0.2,  vm123-5.comain.com\"\n\"app_2,  1.0.1,  vm333-1.comain.com\"\n\"app_33, 0.44.1, vm888-9.comain.com\"\n\"app_33, 1.2.2,  vm123-4.comain.com\"",
      "jq -r '.software | to_entries[] | .key as $app | .value | to_entries[] | select((.value | objects)) |  [$app, .key, .value.server] | @csv'",
      ".software | to_entries[] | \"\\(.key) \\(.value | to_entries[] | select(.key != \\\"latest_version\\\") | \\(.key) \\(.value.server))\""
    ],
    "utterance": "List all application names, version numbers, and server names, excluding any entries where the key is 'latest_version'.",
    "expressions": [
      ".software | to_entries[] | .key as $app | .value | to_entries[] | select((.value | objects)) |  [$app, .key, .value.server] | @csv",
      ".software | to_entries[] | \"\\(.key) \\(.value | to_entries[] | select(.key != \\\"latest_version\\\") | \\(.key) \\(.value.server))\""
    ],
    "data": [
      {
        "input": {
          "software": {
            "app_1": {
              "0.0.1": {
                "properties_1": {
                  "lang": "en"
                },
                "server": "vm123-4.domain.com"
              },
              "0.0.2": {
                "properties_2": {
                  "arch": "x86"
                },
                "server": "vm123-5.comain.com"
              },
              "latest_version": "0.0.2"
            },
            "app_2": {
              "1.0.1": {
                "properties_2": {
                  "arch": "x86"
                },
                "server": "vm333-1.domain.com"
              },
              "latest_version": "1.0.1"
            },
            "app_33": {
              "0.44.1": {
                "properties_1": {
                  "lang": "en"
                },
                "properties_2": {
                  "arch": "x86"
                },
                "properties_3": {
                  "boot": "true"
                },
                "server": "vm888-9.domain.com"
              },
              "1.2.2": {
                "properties_3": {
                  "boot": "yes"
                },
                "server": "vm123-4.domain.com"
              },
              "latest_version": "1.2.2"
            }
          }
        },
        "output": [
          "\"app_1,  0.0.1,  vm123-4.domain.com\"",
          "\"app_1,  0.0.2,  vm123-5.comain.com\"",
          "\"app_2,  1.0.1,  vm333-1.comain.com\"",
          "\"app_33, 0.44.1, vm888-9.comain.com\"",
          "\"app_33, 1.2.2,  vm123-4.comain.com\""
        ]
      }
    ],
    "identifier": 70420500
  },
  {
    "context": [
      "I am attempting to use the `--arg VariableName VariableData` notation.",
      "jq --arg date \"$date\" '.sections[0].builds += [{\"title\": \"Version MyVersion\", \"timestamp\": \"$date\", \"iOS\": \"My_URL.plist\" }]' builds.json > builds1.json",
      "In the outputted JSON, the literal string $date is outputted instead of the variable.",
      "Replace `\"$date\"` with $date in your filter."
    ],
    "utterance": "Add an object to the first sections[0].builds array, setting the timestamp field to the value passed via the date variable.",
    "expressions": [
      ".sections[0].builds += [{\"title\": \"Version MyVersion\", \"timestamp\": $date, \"iOS\": \"My_URL.plist\" }]"
    ],
    "data": [
      {
        "input": {
          "title": "MY Title",
          "columnCount": 1,
          "notes_OFF": "First_Test",
          "sections": [
            {
              "title": "My Title",
              "builds": []
            }
          ]
        },
        "output": {
          "title": "MY Title",
          "columnCount": 1,
          "notes_OFF": "First_Test",
          "sections": [
            {
              "title": "My Title",
              "builds": [
                {
                  "title": "Version MyVersion",
                  "timestamp": "the_value_of_date_variable",
                  "iOS": "My_URL.plist"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 70466960
  },
  {
    "context": [
      "I\u2019d like `extension` doesn\u2019t appear:",
      "extend your function `pick_extension` for the desired output:",
      "def pick_extension:\n  [pick_nationality, pick_surname] as $extension\n  | { use: \"official\" }\n  | if $extension | length > 0 then . + {extension: $extension} else . end;",
      "You can simply add \n| del(..|select(. == []))\nas a trailing to your script in order to remove all such empty arrays"
    ],
    "utterance": "Return objects where the 'extension' field is included only if it contains elements; omit 'extension' if it would be an empty array.",
    "expressions": [
      "def pick_extension: [pick_nationality, pick_surname] as $extension | { use: \"official\" } | if $extension | length > 0 then . + {extension: $extension} else . end; map(pick_extension)",
      "map(pick_extension) | del(..|select(. == []))"
    ],
    "data": [
      {
        "input": [
          {
            "SURNAME": "surname1"
          },
          {
            "NACIONALITAT": "nacionalitat1"
          },
          {
            "field1": "value1"
          },
          {
            "field2": "value2"
          }
        ],
        "output": [
          {
            "use": "official",
            "extension": [
              {
                "name": {
                  "surname": "surname1",
                  "code": "some code"
                }
              }
            ]
          },
          {
            "use": "official",
            "extension": [
              {
                "nation": {
                  "country": "nacionalitat1",
                  "code": "some code"
                }
              }
            ]
          },
          {
            "use": "official"
          },
          {
            "use": "official"
          }
        ]
      }
    ],
    "identifier": 70467640
  },
  {
    "context": [
      "Now I need to loop thorough array and get id and volume values into 2 variables if version startswith 21a. No need to form another json",
      "You can use `startswith` builtin function such as \n```\njq -r '.Storages[] | select(.version | startswith(\"21a\")) | {id, Volume}' \n```",
      "jq -r '.Storages[] | select(.version|startswith(\"21a\"))| .id, .Volume'"
    ],
    "utterance": "Extract id and Volume fields from each object where version starts with 21a",
    "expressions": [
      ".Storages[] | select(.version | startswith(\"21a\")) | {id, Volume}",
      ".Storages[] | select(.version | startswith(\"21a\")) | .id, .Volume"
    ],
    "data": [
      {
        "input": {
          "Storages": [
            {
              "Creation": "2020-04-21T14:01:54",
              "Modified": "2020-04-21T14:01:54",
              "Volume": "/dev/null",
              "id": 10000,
              "version": "20190925-230722"
            },
            {
              "Creation": "2020-04-22T14:01:54",
              "Modified": "2020-04-22T14:01:54",
              "Volume": "/opt/home",
              "id": 10001,
              "version": "22a-20190925-230722"
            },
            {
              "Creation": "2020-04-23T14:01:54",
              "Modified": "2020-04-23T14:01:54",
              "Volume": "/home/abcd",
              "id": 10003,
              "version": "21c-20190925-230722"
            }
          ]
        },
        "output": [
          {
            "id": 10003,
            "Volume": "/home/abcd"
          }
        ]
      }
    ],
    "identifier": 70472404
  },
  {
    "context": [
      "i would like to get all object in a file one by line :",
      "{ \"name\":\"1\" }",
      "{ \"name\":\"2\" }",
      "{ \"name\":\"3\" }",
      "{ \"name\":\"4\" }",
      "and my file is very big and i'm using the stream option.",
      "Here is my attempt so far :",
      "jq --stream -c '.[]' car.json > result.json",
      "but it gives me :",
      "[0,\"name\"]",
      "\"1\"",
      "[1,\"name\"]",
      "\"2\"",
      "you might be able to use the simpler of the two possibilities given there:",
      "jq -cn --stream 'fromstream(1|truncate_stream(inputs))'"
    ],
    "utterance": "Output each object from a top-level array in the input, one object per line.",
    "expressions": [
      "jq -c '.[]'",
      "jq -cn --stream 'fromstream(1|truncate_stream(inputs))'"
    ],
    "data": [
      {
        "input": [
          {
            "name": "1"
          },
          {
            "name": "2"
          },
          {
            "name": "3"
          },
          {
            "name": "4"
          }
        ],
        "output": [
          {
            "name": "1"
          },
          {
            "name": "2"
          },
          {
            "name": "3"
          },
          {
            "name": "4"
          }
        ]
      }
    ],
    "identifier": 70472812
  },
  {
    "context": [
      "Problem is I need to avoid pick_natinality when `.NATIONALITAT` field is not present...",
      "Desired result would be:\n\n[\n  [\n    {\n      \"name\": {\n        \"surname\": \"surname1\",\n        \"code\": \"some code\"\n      }\n    }\n  ],\n  [\n    {\n      \"nation\": {\n        \"country\": \"nacionalitat1\",\n        \"code\": \"some code\"\n      }\n    }\n  ]\n]\n",
      "You can add a test before capture the value :",
      "def pick_nationality:\n  if has(\"NACIONALITAT\")\n  then {nation: {country: .NACIONALITAT, code: \"some code\"} }\n  else empty end;",
      "def pick_surname: \n  if has(\"SURNAME\")\n  then {name: {surname: .SURNAME, code: \"some code\"} }\n  else empty end;",
      "map([pick_nationality, pick_surname])",
      "Just have the functions return nothing when the relevant field is missing.",
      "def pick_nationality:\n  select(.NACIONALITAT) |\n  {nation: {country: .NACIONALITAT, code: \"some code\"} };",
      "def pick_surname: \n  select(.SURNAME) |\n  {name: {surname: .SURNAME, code: \"some code\"} };",
      "map([pick_nationality, pick_surname])"
    ],
    "utterance": "Output an array of objects, each containing either a 'nation' field if 'NACIONALITAT' exists or a 'name' field if 'SURNAME' exists, excluding entries where the respective field is missing.",
    "expressions": [
      "def pick_nationality:\n  if has(\"NACIONALITAT\")\n  then {nation: {country: .NACIONALITAT, code: \"some code\"} }\n  else empty end;\ndef pick_surname: \n  if has(\"SURNAME\")\n  then {name: {surname: .SURNAME, code: \"some code\"} }\n  else empty end;\nmap([pick_nationality, pick_surname])",
      "def pick_nationality:\n  select(.NACIONALITAT) |\n  {nation: {country: .NACIONALITAT, code: \"some code\"} };\ndef pick_surname: \n  select(.SURNAME) |\n  {name: {surname: .SURNAME, code: \"some code\"} };\nmap([pick_nationality, pick_surname])"
    ],
    "data": [
      {
        "input": [
          {
            "SURNAME": "surname1"
          },
          {
            "NACIONALITAT": "nacionalitat1"
          }
        ],
        "output": [
          [
            {
              "name": {
                "surname": "surname1",
                "code": "some code"
              }
            }
          ],
          [
            {
              "nation": {
                "country": "nacionalitat1",
                "code": "some code"
              }
            }
          ]
        ]
      }
    ],
    "identifier": 70455986
  },
  {
    "context": [
      "az sql db list --resource-group $DB_RG --server $SERVER_NAME --query [*].id | grep -v master 2>/dev/null",
      "If you want to use `jq`, you could replace the grep with something like",
      "jq 'map(select(index(\"master\")|not))'"
    ],
    "utterance": "Exclude array elements whose value includes 'master' from a list of database IDs.",
    "expressions": [
      "map(select(index(\"master\")|not))"
    ],
    "identifier": 70473422
  },
  {
    "context": [
      "I want to combine consecutive integers in a sorted array and replace them with ranges using `jq`.",
      "input: `[1,2,3,4,6,98,99,101]`",
      "desired output: `\"1-4,6,98-99,101\"`",
      "input: `[1,3,5]`",
      "desired output: `\"1,3,5\"`",
      "input: `[1,2,3,4,5]`",
      "desired output:  `\"1-5\"`",
      "reduce .[] as $_ (\n   [];\n   if $_ - 1 == .[-1][1] then\n      .[-1][1] = $_\n   else\n      . + [ [ $_, $_ ] ]\n   end\n)",
      "map(\n   if .[0] == .[1] then\n      \"\\( .[0] )\"\n   else\n      \"\\( .[0] )-\\( .[1] )\"\n   end\n) |\njoin(\",\")",
      "reduce .[1:][] as $n ([.[:1]];\n  if $n == .[-1][-1] + 1 then .[-1][1] = $n else . + [[$n]] end\n) | map(join(\"-\")) | join(\",\")",
      "When fed with\n[1,2,3,4,6,98,99,101]\n[1,3,5]\n[1,2,3,4,5]\n[4]\n[]\nit outputs\n\"1-4,6,98-99,101\"\n\"1,3,5\"\n\"1-5\"\n\"4\"\n\"\""
    ],
    "utterance": "Combine consecutive integers in a sorted array and replace them with ranges formatted as \"start-end\" for ranges or a single number otherwise, separated by commas.",
    "expressions": [
      "reduce .[] as $_ (\n   [];\n   if $_ - 1 == .[-1][1] then\n      .[-1][1] = $_\n   else\n      . + [ [ $_, $_ ] ]\n   end\n)\n| map(\n   if .[0] == .[1] then\n      \"\\( .[0] )\"\n   else\n      \"\\( .[0] )-\\( .[1] )\"\n   end\n) |\njoin(\",\")",
      "reduce .[1:][] as $n ([.[:1]];\n  if $n == .[-1][-1] + 1 then .[-1][1] = $n else . + [[$n]] end\n) | map(join(\"-\")) | join(\",\")"
    ],
    "data": [
      {
        "input": [
          1,
          2,
          3,
          4,
          6,
          98,
          99,
          101
        ],
        "output": "1-4,6,98-99,101"
      },
      {
        "input": [
          1,
          3,
          5
        ],
        "output": "1,3,5"
      },
      {
        "input": [
          1,
          2,
          3,
          4,
          5
        ],
        "output": "1-5"
      },
      {
        "input": [
          4
        ],
        "output": "4"
      },
      {
        "input": [],
        "output": ""
      }
    ],
    "identifier": 70467714
  },
  {
    "context": [
      "I want to filter out unique product.id into the array variable.",
      "Actual output:\n123\n123\n123\n456\n456\nnull\nnull",
      "Expected output: \n123\n456",
      "You can use `unique` after applying array conversion and then `join` such as\n```\nproductIds=$(jq -r '[.items[].product.id] | unique | join(\" \")' $Outputfile)\n```"
    ],
    "utterance": "Extract the unique non-null product.id values from all items as a space-separated list.",
    "expressions": [
      "[.items[].product.id] | unique | map(select(. != null)) | join(\" \")",
      "[.items[].product.id | select(. != null)] | unique | join(\" \")"
    ],
    "data": [
      {
        "input": {
          "documentType": "product",
          "items": [
            {
              "ResourceId": null,
              "product": {
                "href": null,
                "id": "123",
                "mainId": "qwe345",
                "primaryId": "5298"
              },
              "lastModifiedBy": "test",
              "quantity": null,
              "effectiveDate": null,
              "extensions": null
            },
            {
              "product": {
                "href": null,
                "id": "123",
                "mainId": "qwe678",
                "primaryId": "5643"
              },
              "lastModifiedBy": "test",
              "quantity": null,
              "effectiveDate": null,
              "extensions": null
            }
          ],
          "createdBy": "test",
          "createdOn": "2021-10-05",
          "currentSeqNum": 2
        },
        "output": "123"
      }
    ],
    "identifier": 70473090
  },
  {
    "context": [
      "The output I am expecting is without `multiple dictionaries` as below",
      "{\r\n  \"Component 1\": [\r\n    \"abc\",\r\n    \"123\",\r\n    \"xyz\"\r\n  ]\r\n}\r\n{\r\n  \"Component 2\": [\r\n    \"def\",\r\n    \"foo\",\r\n    \"bar\"\r\n  ]\r\n}\r\n{\r\n  \"Component 3\": [\r\n    \"def\"\r\n  ]\r\n}",
      "You can convert to this one",
      "jq '.[] | { (.description) : .tags }'",
      "in order to get rid of multiple occurences"
    ],
    "utterance": "Output a single dictionary per array element, with the element's description as key and tags as value.",
    "expressions": [
      ".[] | { (.description): .tags }"
    ],
    "data": [
      {
        "input": [
          {
            "description": "Component 1",
            "tags": [
              "abc",
              "123",
              "xyz"
            ]
          },
          {
            "description": "Component 2",
            "tags": [
              "def",
              "foo",
              "bar"
            ]
          },
          {
            "description": "Component 3",
            "tags": [
              "def"
            ]
          }
        ],
        "output": [
          {
            "Component 1": [
              "abc",
              "123",
              "xyz"
            ]
          },
          {
            "Component 2": [
              "def",
              "foo",
              "bar"
            ]
          },
          {
            "Component 3": [
              "def"
            ]
          }
        ]
      }
    ],
    "identifier": 70480119
  },
  {
    "context": [
      "What I'm trying to do is select only some items from different positions within the hierarchy as follows:",
      "{ \"product\": { \"A_key1\": \"valueA1\", \"A_key3\": {\"keyA3y_nested\": \"valueA3y_nested\"} \"B_key1\": \"valueB1\", \"B_key3\": {\"keyB3y_nested\": \"valueB3y_nested\";} } }",
      "but how do I just pull information selectively from lower in the hierarchy?",
      "this code should work for you:",
      "jq -r '(.product[0] | .A_key1, .A_key3.keyA3y_nested), (.product[1] | .B_key1, .B_key3.keyB3y_nested)'"
    ],
    "utterance": "Extract A_key1 and A_key3.keyA3y_nested from the first element and B_key1 and B_key3.keyB3y_nested from the second element in product, returning them as keys within a single product object.",
    "expressions": [
      "{product: {A_key1: .product[0].A_key1, A_key3: {keyA3y_nested: .product[0].A_key3.keyA3y_nested}, B_key1: .product[1].B_key1, B_key3: {keyB3y_nested: .product[1].B_key3.keyB3y_nested}}}"
    ],
    "data": [
      {
        "input": {
          "product": [
            {
              "A_key1": "valueA1",
              "A_key2": "valueA2",
              "A_key3": {
                "keyA3x_nested": "valueA3x_nested",
                "keyA3y_nested": "valueA3y_nested"
              }
            },
            {
              "B_key1": "valueB1",
              "B_key2": "valueB2",
              "B_key3": {
                "keyB3x_nested": "valueB3x_nested",
                "keyB3y_nested": "valueB3y_nested"
              }
            }
          ]
        },
        "output": {
          "product": {
            "A_key1": "valueA1",
            "A_key3": {
              "keyA3y_nested": "valueA3y_nested"
            },
            "B_key1": "valueB1",
            "B_key3": {
              "keyB3y_nested": "valueB3y_nested"
            }
          }
        }
      }
    ],
    "identifier": 70479157
  },
  {
    "context": [
      "What is the reason the following jq duplicate the results:",
      "If you want to iterate jut once, pull out the iterator `.records[]` up front to define a common input context for the subsequent filter:",
      "```\n.records[] | {junction:.nas.path} + {uuid:.uuid}\n```",
      "This can then further be simplified to\n```\n.records[] | {junction:.nas.path, uuid}\n```",
      "which is presumably what you were looking for."
    ],
    "utterance": "Extract for each element in records the nas.path as 'junction' and the uuid, one per object.",
    "expressions": [
      ".records[] | {junction: .nas.path, uuid}",
      ".records[] | {junction: .nas.path} + {uuid: .uuid}"
    ],
    "data": [
      {
        "input": {
          "records": [
            {
              "uuid": "14e20b5a-6619-11ec-a838-0050568168f7",
              "nas": {
                "path": "/data/nlp/datasets/ds0"
              }
            },
            {
              "uuid": "799ce816-656c-11ec-a838-0050568168f7",
              "nas": {
                "path": "/data/nlp/datasets/ds1"
              }
            }
          ]
        },
        "output": [
          {
            "junction": "/data/nlp/datasets/ds0",
            "uuid": "14e20b5a-6619-11ec-a838-0050568168f7"
          },
          {
            "junction": "/data/nlp/datasets/ds1",
            "uuid": "799ce816-656c-11ec-a838-0050568168f7"
          }
        ]
      }
    ],
    "identifier": 70485305
  },
  {
    "context": [
      "and on using jq command `jq .. kind.json`, i am seeing unexpected output.",
      "This is the [recursive descent](https://jqlang.github.io/jq/manual/v1.6/#recursive-descent) operator `..`. Starting from the input, it recursively descends and produces every value it can find.",
      "First, you see the whole input (the array), then each member of the array (the objects), and after each of them all field values within an object (the strings)."
    ],
    "utterance": "List every value, including nested ones, from an array of objects containing kind fields.",
    "expressions": [
      ".."
    ],
    "data": [
      {
        "input": [
          {
            "kind": "ConfigMap1"
          },
          {
            "kind": "ConfigMap1"
          },
          {
            "kind": "ConfigMap2"
          },
          {
            "kind": "ConfigMap'4"
          },
          {
            "kind": "ConfigMap\"6"
          }
        ]
      }
    ],
    "identifier": 70489706
  },
  {
    "context": [
      "How can I escape _all_ special characters that have meaning in regular expressions (brackets, ., ?, *, + etc.) in the search string so that they are not interpreted as regex syntax?",
      "This should do the trick:",
      "def deregex:\n  reduce (\"\\\\\\\\\", \"\\\\*\", \"\\\\^\", \"\\\\?\", \"\\\\+\", \"\\\\.\", \"\\\\!\", \"\\\\{\", \"\\\\}\", \"\\\\[\", \"\\\\]\", \"\\\\$\", \"\\\\|\", \"\\\\(\", \"\\\\)\" ) as $c \n    (.; gsub( $c; $c));",
      "Example:\n\"^.*$\",\n \"/*\",\n \"*/\"\n| [., deregex]\nproduces:\n[\"^.*$\",\"\\\\^\\\\.\\\\*\\\\$\"]\n[\"/*\",\"/\\\\*\"]\n[\"*/\",\"\\\\*/\"]"
    ],
    "utterance": "Escape all special characters in a search string so it is treated as a literal in a replacement operation.",
    "expressions": [
      "def deregex: reduce (\"\\\\\\\\\", \"\\\\*\", \"\\\\^\", \"\\\\?\", \"\\\\+\", \"\\\\.\", \"\\\\!\", \"\\\\{\", \"\\\\}\", \"\\\\[\", \"\\\\]\", \"\\\\$\", \"\\\\|\", \"\\\\(\", \"\\\\)\") as $c (.; gsub($c; $c));"
    ],
    "data": [
      {
        "input": "^.*$",
        "output": "\\^\\.\\*\\$"
      },
      {
        "input": "/*",
        "output": "/\\*"
      },
      {
        "input": "*/",
        "output": "\\*/"
      }
    ],
    "identifier": 70482956
  },
  {
    "context": [
      "I would like to sort by decending order and output the price of the most recent version.",
      "`cat fruits.json | jq '.fruits | sort_by(-.version)[0].price'`",
      "produces:\n\n`0.52`"
    ],
    "utterance": "Get the price of the fruit with the highest version value.",
    "expressions": [
      ".fruits | sort_by(-.version)[0].price"
    ],
    "data": [
      {
        "input": {
          "fruits": [
            {
              "name": "banana",
              "color": "yellow",
              "price": 0.51,
              "version": 1
            },
            {
              "name": "banana",
              "color": "yellow",
              "price": 0.52,
              "version": 2
            }
          ]
        },
        "output": 0.52
      }
    ],
    "identifier": 70492898
  },
  {
    "context": [
      "cat ~/file1.json | jq -c '.features[]' > converted.json",
      "subprocess.run(['jq', '-c', '.features[]', os.path.expanduser('~/file1.json')], stdout=open('converted.json', 'w'))"
    ],
    "utterance": "Extract each element from the top-level 'features' array in the input, writing them in compact form to the output.",
    "expressions": [
      ".features[]"
    ],
    "identifier": 70502025
  },
  {
    "context": [
      "I want to add a couple fields to a json file in a shell script. The values for both files come in a parameter and there doesn't seem to be a way to make sed or jq work with such values.",
      "sh myscript.sh 'value' 'second value'",
      "firstValue=$1\nsecondValue=$2\n\njq '.firstField=\"'$firstValue'\" | .secondField=\"'$secondValue'\"' $jsonFileAddress",
      "Bengamin W. comment put me on track with the use of arguments. I finally managed to append a couple of new fields to an existing json file like this:",
      "echo $(jq --arg a \"$firstValue\" --arg b \"$secondValue\" '.firstField=$a | .secondField=$b' $jsonFileAddress) > $jsonFileAddress"
    ],
    "utterance": "Add or update two fields in a file with values from shell variables, handling whitespace in those values.",
    "expressions": [
      "jq --arg a \"$firstValue\" --arg b \"$secondValue\" '.firstField=$a | .secondField=$b' $jsonFileAddress"
    ],
    "identifier": 70501541
  },
  {
    "context": [
      "I wanted to get id value(10002) of name test3, with the help of name key.",
      "My requirement is to get id value by inputting the corresponding name value.",
      "Try\n```sh\njq -r --arg name \"test3\" '.values[] | select(.name== $name).id'\n```",
      "```\n10002\n```"
    ],
    "utterance": "Retrieve the id of the entry whose name equals \"test3\".",
    "expressions": [
      "jq -r --arg name \"test3\" '.values[] | select(.name== $name).id'"
    ],
    "data": [
      {
        "input": {
          "self": "https://testtoo.atlassian.net/rest/api/3/project/TEST/version?maxResults=50&startAt=0",
          "maxResults": 50,
          "startAt": 0,
          "total": 2,
          "isLast": true,
          "values": [
            {
              "self": "https://testtoo.atlassian.net/rest/api/3/version/10001",
              "id": "10001",
              "description": "test release",
              "name": "test2",
              "archived": false,
              "released": true,
              "releaseDate": "2021-12-29",
              "userReleaseDate": "29/Dec/21",
              "projectId": 10000
            },
            {
              "self": "https://testtoo.atlassian.net/rest/api/3/version/10002",
              "id": "10002",
              "name": "test3",
              "archived": false,
              "released": true,
              "projectId": 10000
            }
          ]
        },
        "output": "10002"
      }
    ],
    "identifier": 70493870
  },
  {
    "context": [
      "I have around 10,000 JSON files that I need to iterate over and add \n{\n  \"creators\": [\n    {\n      \"address\": \"4iUFmB3H3RZGRrtuWhCMtkXBT51iCUnX8UV7R8rChJsU\",\n      \"share\": 10\n    },\n    {\n      \"address\": \"2JApg1AXvo1Xvrk3vs4vp3AwamxQ1DHmqwKwWZTikS9w\",\n      \"share\": 45\n    },\n    {\n      \"address\": \"Zdda4JtApaPs47Lxs1TBKTjh1ZH2cptjxXMwrbx1CWW\",\n      \"share\": 45\n    }\n  ]\n}\nto",
      "for f in file*.json ;do cat $f | jq  '. +  { creators:[{address: \"xxx\",share:1}] } '  ; done"
    ],
    "utterance": "Add the property 'creators' with three specific address/share pairs to each file in a directory.",
    "expressions": [
      ". + { creators: [ { address: \"4iUFmB3H3RZGRrtuWhCMtkXBT51iCUnX8UV7R8rChJsU\", share: 10 }, { address: \"2JApg1AXvo1Xvrk3vs4vp3AwamxQ1DHmqwKwWZTikS9w\", share: 45 }, { address: \"Zdda4JtApaPs47Lxs1TBKTjh1ZH2cptjxXMwrbx1CWW\", share: 45 } ] }"
    ],
    "identifier": 70502720
  },
  {
    "context": [
      "And i want to retrive the value of key `app.properties` which is nested in `data`. I know the right way of doing this is using -   \r\n`cat explorejq.json |  jq '.data ' | jq '.[\"app.properties\"]'` or    \r\n`cat explorejq.json |  jq '.data | .[\"app.properties\"]'`  and i get   \r\noutput:   `\"some.base64encoded.data\"`    as required",
      "Actually, also `cat explorejq.json |  jq '.data ' | jq '.\"app.properties\"'` would work (or simplified to `jq '.data.\"app.properties\"' explorejq.json`). The relevant part is that `\"app.properties\"` is surrounded by quotes as it needs to be a JSON string (within jq).",
      "First of all, \r\n\r\n```sh\r\ncat explorejq.json | jq '.data ' | jq '.[\"app.properties\"]'\r\n```\r\n\r\nis better written as one of the following:\r\n\r\n```sh\r\njq '.data.[\"app.properties\"]' explorejq.json\r\n```\r\n\r\n```sh\r\njq '.data.\"app.properties\"' explorejq.json\r\n```"
    ],
    "utterance": "Select the value of the key app.properties nested under data in the input, where the key name contains a dot.",
    "expressions": [
      ".data[\"app.properties\"]",
      ".data.\"app.properties\"",
      ".data|.[\"app.properties\"]"
    ],
    "data": [
      {
        "input": {
          "apiVersion": "v1",
          "data": {
            "app.properties": "some.base64encoded.data"
          },
          "kind": "ConfigMap",
          "metadata": {
            "creationTimestamp": "2021-05-17T09:54:15Z",
            "name": "myappproperties",
            "namespace": "myappnamespace",
            "resourceVersion": "352258550",
            "selfLink": "/api/v1/namespaces/myappnamespace/configmap/myappproperties",
            "uid": "cb23197e-54ee-412a-a07a-7d02df3d59a1"
          },
          "type": "IncorrectType"
        },
        "output": "some.base64encoded.data"
      }
    ],
    "identifier": 70488126
  },
  {
    "context": [
      "As you can see, I would like the key to appear in front of the value. Preferably allowing me to change the name of the key (Wind Direction) before printing, but I would also be fine with the original key name (winddir).",
      "\u2026 | jq -r '.observations[]\n  | \"Wind Direction: \\(.winddir)\"\n  , \"Humidity: \\(.humidity)\"\n  , \"Temperature: \\(.imperial.temp)\"\n'",
      "jq -r '.observations[] | {winddir},{humidity},(.imperial| {temp})| \"\\(keys[]) : \\(.[])\"'"
    ],
    "utterance": "Print each value with a label in front, using custom labels like Wind Direction, Humidity, and Temperature, or using original key names.",
    "expressions": [
      ".observations[] | \"Wind Direction: \\(.winddir)\", \"Humidity: \\(.humidity)\", \"Temperature: \\(.imperial.temp)\"",
      ".observations[] | {winddir},{humidity},(.imperial| {temp})| \"\\(keys[]) : \\(.[])\""
    ],
    "data": [
      {
        "input": {
          "observations": [
            {
              "winddir": 292,
              "humidity": 92,
              "qcStatus": 1,
              "imperial": {
                "temp": 20,
                "heatIndex": 20,
                "dewpt": 40,
                "windChill": 20,
                "windSpeed": 3,
                "windGust": 3,
                "pressure": 29.71,
                "precipRate": 0,
                "precipTotal": 0.01,
                "elev": 1905
              }
            }
          ]
        },
        "output": [
          "Wind Direction: 292",
          "Humidity: 92",
          "Temperature: 20"
        ]
      },
      {
        "input": {
          "observations": [
            {
              "winddir": 292,
              "humidity": 92,
              "qcStatus": 1,
              "imperial": {
                "temp": 20,
                "heatIndex": 20,
                "dewpt": 40,
                "windChill": 20,
                "windSpeed": 3,
                "windGust": 3,
                "pressure": 29.71,
                "precipRate": 0,
                "precipTotal": 0.01,
                "elev": 1905
              }
            }
          ]
        },
        "output": [
          "winddir : 292",
          "humidity : 92",
          "temp : 20"
        ]
      }
    ],
    "identifier": 70523457
  },
  {
    "context": [
      "I need to get those objects which belong to the intersections of those groups.",
      "The parent groups are `PROM_FD_ARCNA`, `PROM_JOB_ICMP` and `PROM_JOB_WIN`.",
      "If my explanation was not good, I need to get a JSON like this:",
      "PROM_FD_ARCNA, PROM_JOB_ICMP\n{\n\"HCC02155\"\n}\nPROM_FD_ARCNA, PROM_JOB_WIN \n{\n\"VM00006\"\n}\n",
      "def to_set(s): reduce s as $_ ( {}; .[ $_ ] = true );",
      "[ \"PROM_FD_ARCNA\", \"PROM_JOB_ICMP\", \"PROM_JOB_WIN\" ] as $roots |",
      "[ ...\n   range( 0;    $roots | length ) as $i |  $roots[ $i ] as $g1 |\n   range( $i+1; $roots | length ) as $j |  $roots[ $j ] as $g2 |\n   {\n      root_rgs: [ $g1, $g2 ],\n      names: [ ... ]\n   } |\n   select( .names | length > 0 )\n]",
      "produces\n[\n  {\n    \"root_rgs\": [\n      \"PROM_FD_ARCNA\",\n      \"PROM_JOB_ICMP\"\n    ],\n    \"names\": [\n      \"HCC02155\"\n    ]\n  },\n  {\n    \"root_rgs\": [\n      \"PROM_FD_ARCNA\",\n      \"PROM_JOB_WIN\"\n    ],\n    \"names\": [\n      \"VM00006\"\n    ]\n  }\n]\n"
    ],
    "utterance": "Find all object names that belong to intersections of any two of the following groups: PROM_FD_ARCNA, PROM_JOB_ICMP, PROM_JOB_WIN.",
    "expressions": [
      "def to_set(s): reduce s as $_ ( {}; .[ $_ ] = true );\n\n[ \"PROM_FD_ARCNA\", \"PROM_JOB_ICMP\", \"PROM_JOB_WIN\" ] as $roots |\n\nmap(\n   {\n      name,\n      has_rg: to_set( .rgs | split( \", \" )[] )\n   }\n) as $hosts |\n\n[\n   range( 0;    $roots | length ) as $i |  $roots[ $i ] as $g1 |\n   range( $i+1; $roots | length ) as $j |  $roots[ $j ] as $g2 |\n   {\n      root_rgs: [ $g1, $g2 ],\n      names: [\n         $hosts[] |\n         select( .has_rg[ $g1 ] and .has_rg[ $g2 ] ) |\n         .name\n      ]\n   } |\n   select( .names | length > 0 )\n]"
    ],
    "data": [
      {
        "input": [
          {
            "id_ci": "487006",
            "name": "LABTNSARWID625",
            "id_ci_class": "host",
            "rgs": "PROM_FD_ARCNA, PROM_FD_ARCNA_TGM, PROM_FD_ARCNA_TGM_TGA"
          },
          {
            "id_ci": "5706",
            "name": "HCCQ2001",
            "id_ci_class": "host",
            "rgs": "PROM_JOB_ICMP"
          },
          {
            "id_ci": "9106",
            "name": "HCC02155",
            "id_ci_class": "host",
            "rgs": "PROM_FD_ARCNA, PROM_FD_ARCNA_TGA, PROM_JOB_ICMP"
          },
          {
            "id_ci": "2306",
            "name": "VM00006",
            "id_ci_class": "host",
            "rgs": "PROM_FD_ARCNA, PROM_FD_ARCNA_TGA, PROM_JOB_WIN, PROM_JOB_WIN_TGA"
          }
        ],
        "output": [
          {
            "root_rgs": [
              "PROM_FD_ARCNA",
              "PROM_JOB_ICMP"
            ],
            "names": [
              "HCC02155"
            ]
          },
          {
            "root_rgs": [
              "PROM_FD_ARCNA",
              "PROM_JOB_WIN"
            ],
            "names": [
              "VM00006"
            ]
          }
        ]
      }
    ],
    "identifier": 70522587
  },
  {
    "context": [
      "print just the attributes->preferences section in the following JSON example using jq.",
      "I need the attributes->preferences section just from the array element with id 1 without knowing the exact order of the array entries ahead of time.",
      "jq '.[] | select( .id == 1 ) | .attributes.preferences'"
    ],
    "utterance": "Retrieve the preferences object under attributes for the array element with id equal to 1.",
    "expressions": [
      ".[] | select( .id == 1 ) | .attributes.preferences"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "attributes": {
              "preferences": {
                "key1": "value1",
                "key2": "value2",
                "key3": "value3",
                "key4": "value4"
              }
            }
          },
          {
            "id": 2,
            "attributes": {
              "preferences": {
                "key1": "othervalue1"
              }
            }
          }
        ],
        "output": {
          "key1": "value1",
          "key2": "value2",
          "key3": "value3",
          "key4": "value4"
        }
      }
    ],
    "identifier": 70535534
  },
  {
    "context": [
      "The output I am expecting is without `multiple dictionaries` as below",
      "How can I generate the above-expected output using JQ?",
      "jq 'group_by(.project)[] \n             | { project: .[0].project, status:.[0].status, \"description\": [.[] \n             | { (.description) : .tags|join(\";\") } ] }'"
    ],
    "utterance": "Group objects by project, for each group output the project and status, and make an array with each description as key and joined tags as value, so each group appears once.",
    "expressions": [
      "group_by(.project)[] | { project: .[0].project, status:.[0].status, \"description\": [.[] | { (.description) : .tags|join(\";\") } ] }",
      "group_by(.project)[] | (first | {project, status}) + {description: map({(.description): .tags | join(\";\")})}"
    ],
    "data": [
      {
        "input": [
          {
            "id": 6,
            "description": "Component 1",
            "due": "20211122T183000Z",
            "entry": "20211119T181735Z",
            "modified": "20211119T181735Z",
            "project": "product1",
            "status": "pending",
            "uuid": "55bf0497-208c-492a-8f76-bb692d48afaa",
            "tags": [
              "abc",
              "123"
            ],
            "urgency": 13.9699
          },
          {
            "id": 10,
            "description": "Component 2",
            "due": "20211129T183000Z",
            "entry": "20211130T045620Z",
            "modified": "20211130T045620Z",
            "project": "product2",
            "status": "pending",
            "uuid": "d57eb8f7-e5ec-497c-ac47-f1cf34b005db",
            "tags": [
              "foo",
              "bar"
            ],
            "urgency": 14.0151
          },
          {
            "id": 11,
            "description": "Component 3",
            "due": "20211202T183000Z",
            "entry": "20211130T121529Z",
            "completed": "20211130T123915Z",
            "project": "product3",
            "status": "pending",
            "uuid": "9f15e6a4-5cef-4b0f-915b-fc916ab152c7",
            "tags": [
              "xyz",
              "676"
            ],
            "urgency": 14.0096
          },
          {
            "id": 12,
            "description": "Component 4",
            "due": "20211202T183000Z",
            "entry": "20211130T122537Z",
            "pending": "20211130T122537Z",
            "project": "product1",
            "status": "pending",
            "uuid": "91c9ec76-42a7-4ebc-9649-b3a12027feb1",
            "tags": [
              "def"
            ],
            "urgency": 13.9096
          }
        ],
        "output": [
          {
            "project": "product1",
            "status": "pending",
            "description": [
              {
                "Component 1": "abc;123"
              },
              {
                "Component 4": "def"
              }
            ]
          },
          {
            "project": "product2",
            "status": "pending",
            "description": [
              {
                "Component 2": "foo;bar"
              }
            ]
          },
          {
            "project": "product3",
            "status": "pending",
            "description": [
              {
                "Component 3": "xyz;676"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 70481609
  },
  {
    "context": [
      "I want to parse the following json array that comes out of AWS GetMetricData API. It contains the timestamps and values in different arrays:",
      "I'm trying to transform it to a table that looks like this:\nTimestamp | Value | Id\n2021-12-28T02:11:00Z | 5.0 | groupDesiredCapacity",
      "I googled around and came up with this jq query\n`.MetricDataResults[] | {t: .Timestamps[], v: .Values[],i: .Id}|[.t,.v,.i]|@csv`\nbut it seems to \"multiply\" the values instead of mapping them.",
      "Use the `transpose` builtin to match the array members to each other",
      "jq -r '.MetricDataResults[] | ([.Timestamps, .Values] | transpose[]) + [.Id] | @csv'",
      "If you want to have your desired output format instead of csv, replace `@csv` with `join(\" | \")`",
      "jq -r '.MetricDataResults[] | ([.Timestamps, .Values] | transpose[]) + [.Id] | join(\" | \")'",
      "A straightforward alternative:",
      ".MetricDataResults[]\n| .Id as $Id\n| range(0; .Timestamps|length) as $i\n| [.Timestamps[$i], .Values[$i], $Id]\n| @csv"
    ],
    "utterance": "For each entry, pair each timestamp with the value at the same index and the corresponding Id, outputting each row as Timestamp | Value | Id.",
    "expressions": [
      ".MetricDataResults[] | ([.Timestamps, .Values] | transpose[]) + [.Id] | @csv",
      ".MetricDataResults[] | ([.Timestamps, .Values] | transpose[]) + [.Id] | join(\" | \")",
      ".MetricDataResults[] | .Id as $Id | range(0; .Timestamps|length) as $i | [.Timestamps[$i], .Values[$i], $Id] | @csv"
    ],
    "data": [
      {
        "input": {
          "Messages": [],
          "MetricDataResults": [
            {
              "Timestamps": [
                "2021-12-28T02:11:00Z",
                "2021-12-28T02:10:00Z"
              ],
              "StatusCode": "Complete",
              "Values": [
                5.0,
                2.0
              ],
              "Id": "groupDesiredCapacity",
              "Label": "myRequestLabel"
            }
          ]
        },
        "output": [
          "\"2021-12-28T02:11:00Z\",5,\"groupDesiredCapacity\"",
          "\"2021-12-28T02:10:00Z\",2,\"groupDesiredCapacity\""
        ]
      }
    ],
    "identifier": 70503009
  },
  {
    "context": [
      "Required output is as below : \r\n\r\n    AMIT||220000d7f728801,A1,1073741824,0,0\r\n    AMIT||220000d7f728801,B1,5368709120,5368709120,5368709120\r\n    AMIT||220000d7f728801,A2,1073741824,0,0\r\n    AMIT||220000d7f728801,B2,10737418240,10737418240,10737418240\r\n    AMIT||220000d7f728801,B3,2147483648,2147483648,2147483648",
      "jq -r '.[] | [.name[0] , (.List[0].Insts[0] | .DefId, .data1, .data2, .data3)] | join(\",\")'",
      "jq -r 'to_entries[] | .value | [ .name[] , (.List[].Insts | select( . != null ) | .[] | .DefId, \"\\(.data1)\", \"\\(.data2)\", \"\\(.data3)\" ) ]  | join(\",\")'"
    ],
    "utterance": "Extract rows combining the first element of the 'name' array, the 'DefId', 'data1', 'data2', and 'data3' from each Insts object, formatted as comma-separated values.",
    "expressions": [
      ".[] | [.name[0], (.List[0].Insts[0] | .DefId, .data1, .data2, .data3)] | join(\",\")",
      "to_entries[] | .value | [ .name[] , (.List[].Insts | select( . != null ) | .[] | .DefId, \"\\(.data1)\", \"\\(.data2)\", \"\\(.data3)\" ) ]  | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "e4624072-a9a2-4181-9649-550b9cfeb7cd||220000d7f738801": {
            "List": [
              {
                "Insts": [
                  {
                    "DefId": "A1",
                    "data1": 1073741824,
                    "data2": 0,
                    "data3": 0
                  }
                ]
              }
            ],
            "name": [
              "AMIT||220000d7f728801"
            ],
            "id": "e4624072-a9a2-4181-9649-550b9cfeb7cd||220000d7f738801",
            "endTime": 96285337200000
          },
          "0b1141b2-c2de-47c9-aa0c-2742f92b63f2||220000d7f738801": {
            "List": [
              {
                "Insts": [
                  {
                    "DefId": "B1",
                    "data1": 5368709120,
                    "data2": 5368709120,
                    "data3": 5368709120
                  }
                ]
              },
              {
                "edigest": "MV6shIv5NE5vWkc0cx6Q/JTwid4=",
                "csDefRef": "BoostYES_B1"
              },
              {
                "edigest": "MV6shIv5NE5vWkc0cx6Q/JTwid4=",
                "csDefRef": "BoostOff_B1"
              }
            ],
            "name": [
              "AMIT||220000d7f728801"
            ],
            "id": "0b1141b2-c2de-47c9-aa0c-2742f92b63f2||220000d7f738801",
            "lifeCycle": 0
          },
          "23e529f9-b2f3-4730-9b28-4ee05ca678b6||220000d7f738801": {
            "List": [
              {
                "Insts": [
                  {
                    "DefId": "A2",
                    "data1": 1073741824,
                    "data2": 0,
                    "data3": 0,
                    "lastUpdateTime": 1619541451476,
                    "origInitialVal": 1073741824
                  }
                ]
              }
            ],
            "name": [
              "AMIT||220000d7f728802"
            ],
            "id": "23e529f9-b2f3-4730-9b28-4ee05ca678b6||220000d7f738801",
            "endTime": 96285337200000,
            "lifeCycle": 0
          },
          "66b2229b-2c16-4d54-b2a8-fcc1baeaf51c||220000d7f738801": {
            "List": [
              {
                "Insts": [
                  {
                    "DefId": "B2",
                    "data1": 10737418240,
                    "data2": 10737418240,
                    "data3": 10737418240,
                    "lastUpdateTime": 1637766239807,
                    "origInitialVal": 10737418240
                  }
                ]
              },
              {
                "edigest": "MV6shIv5NE5vWkc0cx6Q/JTwid4=",
                "csDefRef": "RMN_B2"
              }
            ],
            "name": [
              "AMIT||220000d7f728801"
            ],
            "startTime": 1637766000000,
            "id": "66b2229b-2c16-4d54-b2a8-fcc1baeaf51c||220000d7f738801",
            "endTime": 1637852400000,
            "lifeCycle": 0
          },
          "b896eb1b-d6b0-432b-8925-af17431c0f3e||220000d7f738801": {
            "List": [
              {
                "Insts": [
                  {
                    "DefId": "B3",
                    "data1": 2147483648,
                    "data2": 2147483648,
                    "data3": 2147483648,
                    "lastUpdateTime": 1635692405780
                  }
                ]
              },
              {
                "edigest": "MV6shIv5NE5vWkc0cx6Q/JTwid4=",
                "csDefRef": "BoostYES_B3"
              },
              {
                "edigest": "MV6shIv5NE5vWkc0cx6Q/JTwid4=",
                "csDefRef": "BoostOffCS_B3"
              }
            ],
            "name": [
              "AMIT||220000d7f728801"
            ],
            "id": "b896eb1b-d6b0-432b-8925-af17431c0f3e||220000d7f738801",
            "lifeCycle": 0
          }
        },
        "output": [
          "AMIT||220000d7f728801,A1,1073741824,0,0",
          "AMIT||220000d7f728801,B1,5368709120,5368709120,5368709120",
          "AMIT||220000d7f728802,A2,1073741824,0,0",
          "AMIT||220000d7f728801,B2,10737418240,10737418240,10737418240",
          "AMIT||220000d7f728801,B3,2147483648,2147483648,2147483648"
        ]
      }
    ],
    "identifier": 70406005
  },
  {
    "context": [
      "I want to extract all root values contains \"***\" on them.",
      "to_entries[]\n| select( any(.value[]; test(\"\\\\*\\\\*\\\\*\")) )\n| .key",
      "if you want to _dive into_ the encoded JSON contained within the top arrays' third elements and search just in them instead, use the `fromjson` builtin:\nto_entries[]\n| select(any(.value[2] | fromjson | .RegistrationUserID[]; test(\"\\\\*\\\\*\\\\*\")))\n| .key"
    ],
    "utterance": "Extract top-level keys whose values contain elements with the substring \"***\".",
    "expressions": [
      "to_entries[] | select(any(.value[]; test(\"\\*\\*\\*\"))) | .key",
      "to_entries[] | select(any(.value[2] | fromjson | .RegistrationUserID[]; test(\"\\*\\*\\*\"))) | .key"
    ],
    "data": [
      {
        "input": {
          "12": [
            "12",
            "200 OK",
            "{\r\n  \"ResponseText\": null,\r\n  \"RegistrationUserID\": {}\r\n}"
          ],
          "19": [
            "23",
            "200 OK",
            "{\r\n  \"ResponseText\": null,\r\n  \"RegistrationUserID\": {\r\n    \"1\": \"2019***091\",\r\n    \"2\": \"2019****67\"\r\n  }\r\n}"
          ],
          "20": [
            "434",
            "200 OK",
            "{\r\n  \"ResponseText\": null,\r\n  \"RegistrationUserID\": {\r\n    \"1\": \"2019****83\"\r\n  }\r\n}"
          ],
          "333": [
            "25",
            "200 OK",
            "{\r\n  \"ResponseText\": null,\r\n  \"RegistrationUserID\": {\r\n    \"1\": \"2019****32\"\r\n  }\r\n}"
          ],
          "3454": [
            "55",
            "200 OK",
            "{\r\n  \"ResponseText\": null,\r\n  \"RegistrationUserID\": {\r\n    \"1\": \"2019****1\"\r\n  }\r\n}"
          ],
          "23": [
            "66",
            "200 OK",
            "{\r\n  \"ResponseText\": null,\r\n  \"RegistrationUserID\": {\r\n    \"1\": \"2019****5\"\r\n  }\r\n}"
          ],
          "23424": [
            "34",
            "200 OK",
            "{\r\n  \"ResponseText\": null,\r\n  \"RegistrationUserID\": {\r\n    \"1\": \"2019****2\"\r\n  }\r\n}"
          ]
        },
        "output": [
          "19",
          "20",
          "333",
          "3454",
          "23",
          "23424"
        ]
      }
    ],
    "identifier": 70539704
  },
  {
    "context": [
      "I'm trying to generate a list of hosts including disks + sizes and partitions + sizes AND mount points.",
      "But because the mount information is an array (I think?) i need to map it to get it to work? I'd like to get the results in the same list as the one above but when i add it in it works, but it gives me a new list for every mount point instead of just one list!",
      "BUT, this is what I'm trying to get:",
      "{ \"hostname\": \"ip-172-31-16-55\", \"Disks\": { \"xvda\": \"10.00 GB\" }, \"Partitions\": { \"xvda1\": \"1.00 GB\", \"xvda2\": \"9.00 GB\" }, \"Mounts\": \"/\", \"Mounts\": \"/boot\" }",
      "or even a `,` separated list on one line?",
      "hopefully the following will provide the nudge you're looking for:",
      ".ansible_facts\n| {hostname: .ansible_hostname,\n   Disks: (.ansible_devices | with_entries(.value |= .size)),\n   Partitions: ([.ansible_devices[].partitions | with_entries(.value |= .size)]|add),\n   Mounts: [.ansible_mounts[].mount]\n  }"
    ],
    "utterance": "Return an object containing the host name, a mapping of disks to their sizes, a mapping of partitions to their sizes, and a list of all mount points.",
    "expressions": [
      ".ansible_facts | {hostname: .ansible_hostname, Disks: (.ansible_devices | with_entries(.value |= .size)), Partitions: ([.ansible_devices[].partitions | with_entries(.value |= .size)]|add), Mounts: [.ansible_mounts[].mount]}"
    ],
    "data": [
      {
        "input": {
          "ansible_facts": {
            "ansible_hostname": "ip-172-31-16-55",
            "ansible_devices": {
              "xvda": {
                "size": "10.00 GB",
                "partitions": {
                  "xvda1": {
                    "size": "1.00 GB"
                  },
                  "xvda2": {
                    "size": "9.00 GB"
                  }
                }
              }
            },
            "ansible_mounts": [
              {
                "mount": "/"
              },
              {
                "mount": "/boot"
              }
            ]
          }
        },
        "output": {
          "hostname": "ip-172-31-16-55",
          "Disks": {
            "xvda": "10.00 GB"
          },
          "Partitions": {
            "xvda1": "1.00 GB",
            "xvda2": "9.00 GB"
          },
          "Mounts": [
            "/",
            "/boot"
          ]
        }
      }
    ],
    "identifier": 70543343
  },
  {
    "context": [
      "I\u2019m having the following dataset which I\u2019d like to export into a CSV:",
      "\"And header would be as follow:\"",
      "\"Header keys mapping as follow:\"",
      "what would be the preferred approach to export the data into a csv ? Would using jq's @CSV work though we would have to loop through several nodes ?",
      "jq -r '.data.activeFindings.findings[] \n       | [.findingId , .findingDescription, .findingImpact, .severity, (.recommendations | join(\",\")) , .affectedObjects[].sourceName, .affectedObjects[].objectName, .affectedObjects[].objectType, .affectedObjects[].version, .affectedObjects[].buildNumber, .firstObserved, (.kbLinkURLs | join(\",\")) ] \n       | delpaths([path(.[] | select(.==null))]) \n       | @csv'"
    ],
    "utterance": "Export a flattened table with fields: findingId, findingDescription, findingImpact, severity, recommendations (joined by comma), sourceName, objectName, objectType, version, buildNumber, firstObserved, kbLinkURLs (joined by comma), as CSV, where each row combines a finding with each of its affectedObjects.",
    "expressions": [
      ".data.activeFindings.findings[] | [.findingId , .findingDescription, .findingImpact, .severity, (.recommendations | join(\",\")) , .affectedObjects[].sourceName, .affectedObjects[].objectName, .affectedObjects[].objectType, .affectedObjects[].version, .affectedObjects[].buildNumber, .firstObserved, (.kbLinkURLs | join(\",\")) ] | delpaths([path(.[] | select(.==null))]) | @csv"
    ],
    "data": [
      {
        "input": {
          "data": {
            "activeFindings": {
              "findings": [
                {
                  "findingId": "risk#80703",
                  "accountId": "00000000-000000-0000000-000000",
                  "products": [
                    "GWSERVER01"
                  ],
                  "findingDisplayName": "risk#80703",
                  "severity": "CRITICAL",
                  "findingDescription": "PSOD with re-formatting a valid dedup metadata block.",
                  "findingImpact": "Potential ESXi host crash",
                  "recommendations": [
                    "This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523)",
                    "This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804)"
                  ],
                  "kbLinkURLs": [
                    "https://kb.vmware.com/s/article/80703"
                  ],
                  "recommendationsVCF": [
                    "This issue is resolved with VMware Cloud Foundation 4.1"
                  ],
                  "kbLinkURLsVCF": [
                    "https://kb.vmware.com/s/article/80703"
                  ],
                  "categoryName": "Storage",
                  "findingTypes": [
                    "UPGRADE"
                  ],
                  "firstObserved": 1629806351877,
                  "totalAffectedObjectsCount": 12,
                  "affectedObjects": [
                    {
                      "sourceName": "GWSERVER01.corp.contoso.org",
                      "objectName": "server01.corp.contoso.org",
                      "objectType": "ESX",
                      "version": "6.7.0",
                      "buildNumber": "17499825",
                      "solutionTags": [],
                      "firstObserved": 1629806351877
                    },
                    {
                      "sourceName": "GWSERVER01.corp.contoso.org",
                      "objectName": "server02.corp.contoso.org",
                      "objectType": "ESX",
                      "version": "6.7.0",
                      "buildNumber": "17499825",
                      "solutionTags": [],
                      "firstObserved": 1629806351877
                    }
                  ]
                }
              ],
              "totalRecords": 1,
              "timeTaken": 56
            }
          }
        },
        "output": [
          "\"risk#80703\",\"PSOD with re-formatting a valid dedup metadata block.\",\"Potential ESXi host crash\",\"CRITICAL\",\"This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523),This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804)\",\"GWSERVER01.corp.contoso.org\",\"server01.corp.contoso.org\",\"ESX\",\"6.7.0\",\"17499825\",1629806351877,\"https://kb.vmware.com/s/article/80703\"",
          "\"risk#80703\",\"PSOD with re-formatting a valid dedup metadata block.\",\"Potential ESXi host crash\",\"CRITICAL\",\"This issue is resolved in VMware ESXi 6.7 upgrade to Patch 05 (17700523),This issue is resolved in VMware ESXi 7.0 upgrade to Update 1 (16850804)\",\"GWSERVER01.corp.contoso.org\",\"server02.corp.contoso.org\",\"ESX\",\"6.7.0\",\"17499825\",1629806351877,\"https://kb.vmware.com/s/article/80703\""
        ]
      }
    ],
    "identifier": 70453387
  },
  {
    "context": [
      "archive_ids=$(jq .ArchiveList[].ArchiveId < $file)",
      "jq -c '\n   .ArchiveList[] |\n   {\n      \"Type\":        \"archive-retrieval\",\n      \"Description\": \"Download all my archives\",\n      \"ArchiveId\":   .ArchiveId\n   }\n' \"$file\" |"
    ],
    "utterance": "Extract each object from ArchiveList with Type as \"archive-retrieval\", Description as \"Download all my archives\", and ArchiveId set to the ArchiveId value from the input",
    "expressions": [
      ".ArchiveList[] | {\"Type\": \"archive-retrieval\", \"Description\": \"Download all my archives\", \"ArchiveId\": .ArchiveId}",
      "jq -c '.ArchiveList[] | {\"Type\": \"archive-retrieval\", \"Description\": \"Download all my archives\", \"ArchiveId\": .ArchiveId}' \"$file\""
    ],
    "data": [
      {
        "input": {
          "ArchiveList": [
            {
              "ArchiveId": "abc123",
              "OtherField": "value"
            },
            {
              "ArchiveId": "def456",
              "OtherField": "value2"
            }
          ]
        },
        "output": [
          {
            "Type": "archive-retrieval",
            "Description": "Download all my archives",
            "ArchiveId": "abc123"
          },
          {
            "Type": "archive-retrieval",
            "Description": "Download all my archives",
            "ArchiveId": "def456"
          }
        ]
      }
    ],
    "identifier": 70558211
  },
  {
    "context": [
      "If you decide to use jq, then unless there is some specific reason not to, I'd suggest invoking jq once for each of the three output files.  The three invocations would then look like these:",
      "jq -r '.result.dropped1 | [to_entries[][]] | @csv' > 1.csv",
      "jq -r '.result.rates.total | [\"total\", .[\"1min\"], .[\"5min\"], .[\"15min\"], .[\"60min\"]] | @csv' > 2.csv",
      "jq -r '.result.rates.dropped2\n | to_entries[]\n | [.key] + ( .value | [ .[\"1min\"], .[\"5min\"], .[\"15min\"], .[\"60min\"]] )\n | @csv\n' > 3.csv"
    ],
    "utterance": "Extract dropped1 addresses and totals, total rates for 1min, 5min, 15min, 60min, and dropped2 addresses with their respective rates, each as a CSV line.",
    "expressions": [
      ".result.dropped1 | [to_entries[][]] | @csv",
      ".result.rates.total | [\"total\", .[\"1min\"], .[\"5min\"], .[\"15min\"], .[\"60min\"]] | @csv",
      ".result.rates.dropped2 | to_entries[] | [.key] + ( .value | [ .[\"1min\"], .[\"5min\"], .[\"15min\"], .[\"60min\"]] ) | @csv"
    ],
    "data": [
      {
        "input": {
          "result": {
            "found": 0,
            "dropped1": {
              "address10": 1140
            },
            "rates": {
              "total": {
                "1min": 3579,
                "5min": 1593,
                "15min": 5312,
                "60min": 1328
              },
              "dropped2": {
                "address20": {
                  "1min": 9139,
                  "5min": 8355,
                  "15min": 2785,
                  "60min": 8196
                }
              }
            },
            "connections": 1
          },
          "id": "whatever",
          "jsonrpc": "2.0"
        },
        "output": [
          [
            "address10,1140"
          ],
          [
            "total,3579,1593,5312,1328"
          ],
          [
            "address20,9139,8355,2785,8196"
          ]
        ]
      }
    ],
    "identifier": 70559755
  },
  {
    "context": [
      "I can't work out how to pull out just the part `ONEMTH` from `._links.web_path`",
      "You can use the following to get the desired output.",
      "you can use string interpolation and `split` / array indexing to extract the web path string:",
      "jq -r '\"\b9(.project_id)#\b9(.name)#\b9(._links.web_path | split(\"/\")[3])\"'",
      "[ .project_id, .name, (._links.web_path | split(\"/\")[3]) ] | join(\"#\")"
    ],
    "utterance": "Combine project_id, name, and the fourth segment of _links.web_path, separated by #, where the fourth segment equals ONEMTH.",
    "expressions": [
      "[ .project_id, .name, (._links.web_path | split(\"/\")[3]) ] | join(\"#\")",
      "\"\b9(.project_id)#\b9(.name)#\b9(._links.web_path | split(\"/\")[3])\""
    ],
    "data": [
      {
        "input": {
          "id": 4409976,
          "name": "MKLIU",
          "version": "1.0",
          "package_type": "generic",
          "status": "default",
          "_links": {
            "web_path": "/part1/part2/ONEMTH/part4/-/part5/part6",
            "delete_api_path": "https://example.com/api/v1/part40/part90/part65/part73"
          },
          "created_at": "2019-01-02T10:52:34.857Z",
          "project_id": 667845,
          "project_path": "hereitis/downloads/ONEMTH/MKLIU",
          "tags": []
        },
        "output": "667845#MKLIU#ONEMTH"
      }
    ],
    "identifier": 70561419
  },
  {
    "context": [
      "how do you read json from k8s api - to get the status of a pod - running or not?",
      "curl '127.0.0.1:8080/api/v1/pods' | jq -r '.items[] | select(.metadata.name == \"my-pod\").status.phase'",
      "jq -r '.items[] | select(.metadata.name == \"my-pod\").status.containerStatuses[0].state'"
    ],
    "utterance": "Get the status phase and the container state of the pod named 'my-pod'.",
    "expressions": [
      ".items[] | select(.metadata.name == \"my-pod\").status.phase",
      ".items[] | select(.metadata.name == \"my-pod\").status.containerStatuses[0].state"
    ],
    "identifier": 70583733
  },
  {
    "context": [
      "I have multiple json files that I need to comnine into one giant json file.",
      "here's a cat of the jq\n```\nrfossi@xAMrfossi Responses % cat BBB.json | jq '.[] | { repo: .url[37:-1] | [rtrimstr(\"/branches/master/protectio\")], PushUsers: [.restrictions.users[].login], PushTeams: [.restrictions.teams[].slug]}'\n{\n  \"repo\": [\n    \"homelaunch_basic\"\n  ],\n  \"PushUsers\": [],\n  \"PushTeams\": [\n    \"master-branch-mergers\"\n  ]\n}\n{\n  \"repo\": [\n    \"homelaunch_base\"\n  ],\n  \"PushUsers\": [],\n  \"PushTeams\": []\n}\n```\n\nAs you can see, I get the info I need.  But it's missing the \",\" that makes it a valid json file.",
      "To achieve this, surround your entire filter with brackets `jq '[.[] | {\u2026}]'` and jq will take care of the commas. Also, as your filter's initial part `.[]` was already decomposing an array (or an object), you could simplify the array creation by exchanging it for a `map` with the same effect: `jq 'map({\u2026})'`."
    ],
    "utterance": "Extract specific fields from all items in multiple files and produce a single valid array containing those filtered objects.",
    "expressions": [
      "[.[] | { repo: .url[37:-1] | [rtrimstr(\"/branches/master/protectio\")], PushUsers: [.restrictions.users[].login], PushTeams: [.restrictions.teams[].slug] } ]",
      "map({ repo: .url[37:-1] | [rtrimstr(\"/branches/master/protectio\")], PushUsers: [.restrictions.users[].login], PushTeams: [.restrictions.teams[].slug] })"
    ],
    "identifier": 70573060
  },
  {
    "context": [
      "For example I want to remove all objects whose key is not \"filter\". Desired output:",
      "You can use `to_entries` function such as\n```\njq 'del(.children[] | select( to_entries[] | .key != \"filter\"))'\n```",
      "```jq\njq 'del(.children[] | select(.filter == null))'\n```"
    ],
    "utterance": "Remove all objects from the children array whose only key is not filter.",
    "expressions": [
      "del(.children[] | select( to_entries[] | .key != \"filter\"))",
      "del(.children[] | select(.filter == null))"
    ],
    "data": [
      {
        "input": {
          "name": "config1",
          "children": [
            {
              "customer": {
                "name": "cust1"
              }
            },
            {
              "filter": {
                "name": "test1"
              }
            },
            {
              "filter": {
                "name": "test2"
              }
            },
            {
              "context": {
                "id": "1"
              }
            }
          ]
        },
        "output": {
          "name": "config1",
          "children": [
            {
              "filter": {
                "name": "test1"
              }
            },
            {
              "filter": {
                "name": "test2"
              }
            }
          ]
        }
      }
    ],
    "identifier": 70592888
  },
  {
    "context": [
      "How can i remove item \"blablablablablabla:*\" from \"Condition->ArnLike->aws:bla\" if \"Sid\" == \"bla1\"",
      "First, `select` the items that match the condition `.Sid == \"bla1\"`, then `del`ete from them any entry `.Condition.ArnLike.\"aws:bla\"[]` that matches `. == \"blablablablablabla*\".`",
      "jq 'select(.Sid == \"bla1\") |=\n  del(.Condition.ArnLike.\"aws:bla\"[] | select(. == \"blablablablablabla*\"))\n'",
      "If your objects are in an array, apply this using a `map` onto that array.",
      "jq 'map(select(.Sid == \"bla1\") |=\n  del(.Condition.ArnLike.\"aws:bla\"[] | select(. == \"blablablablablabla*\"))\n)'"
    ],
    "utterance": "Remove the item \"blablablablablabla*\" from the \"aws:bla\" list under Condition->ArnLike when Sid equals \"bla1\".",
    "expressions": [
      "select(.Sid == \"bla1\") |= del(.Condition.ArnLike.\"aws:bla\"[] | select(. == \"blablablablablabla*\"))",
      "map(select(.Sid == \"bla1\") |= del(.Condition.ArnLike.\"aws:bla\"[] | select(. == \"blablablablablabla*\")))"
    ],
    "data": [
      {
        "input": {
          "Sid": "bla1",
          "Effect": "Allow",
          "Principal": {
            "AWS": "*"
          },
          "Action": "blabla",
          "Resource": "blablablabla",
          "Condition": {
            "ArnLike": {
              "aws:bla": [
                "blablablablablabla*",
                "blablablablabla*",
                "blablablabla:*"
              ]
            }
          }
        },
        "output": {
          "Sid": "bla1",
          "Effect": "Allow",
          "Principal": {
            "AWS": "*"
          },
          "Action": "blabla",
          "Resource": "blablablabla",
          "Condition": {
            "ArnLike": {
              "aws:bla": [
                "blablablablabla*",
                "blablablabla:*"
              ]
            }
          }
        }
      }
    ],
    "identifier": 70576220
  },
  {
    "context": [
      "I want name and id of a single item to be passed together as arguments to the function display",
      "You can use string interpolation.",
      "jq '.[] | \"The name is \\(.name) and id \\(.id)\"'",
      "If you want to get rid of the double-quotes from each object, then:",
      "jq --raw-output '.[] | \"The name is \\(.name) and is \\(.id)\"'"
    ],
    "utterance": "Output each object's name and id together as a single string in the format: The name is <name> and id <id>.",
    "expressions": [
      ".[] | \"The name is \\(.name) and id \\(.id)\"",
      "--raw-output '.[] | \"The name is \\(.name) and is \\(.id)\"'"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Akshay",
            "id": "234"
          },
          {
            "name": "Amit",
            "id": "28"
          }
        ],
        "output": [
          "The name is Akshay and id 234",
          "The name is Amit and id 28"
        ]
      }
    ],
    "identifier": 70593928
  },
  {
    "context": [
      "Is there a way to transform / slurp a list of JSON values into an array ?",
      "I would like to have a way to transform the list back into an array but without enclosing the expression with [ ], without using the array constructor.",
      "The code building the array must necessarily enclose STREAM.",
      "* `[ STREAM ]`",
      "* `reduce STREAM as $_ ( []; .+[$_] )`",
      "* `def array( s ): [ s ]; array( STREAM )`",
      "* `ARRAY | map( STREAM )` (An alternative to `[ ARRAY | STREAM ]`.)"
    ],
    "utterance": "Collect a stream or list of values into a single array using a filter, without directly using the array constructor syntax.",
    "expressions": [
      "[ STREAM ]",
      "reduce STREAM as $_ ( []; .+[$_] )",
      "def array( s ): [ s ]; array( STREAM )",
      "ARRAY | map( STREAM )"
    ],
    "identifier": 70594159
  },
  {
    "context": [
      "The \"name\" of the target group is \"root_rgs\" and I'd like to have it in different files each one.",
      "Is it possible to generate something like:\n\n`ARCNA_ICMP.json`\n\n    {\n    TARGETS:\n            \"HCC02155\",\n            \"HCC09350\",\n            \"HCC09321\",\n            \"HCCEFACTORYWWW\",\n            \"HCC9723\"\n    }\n\n-------------------------------------------\n`ARCNA_WIN.json`\n\n    {\n    TARGETS:\n        \"LABTNSARWID236\",\n        \"LABTNSARWID692\",\n        \"VM00006\"\n    }\n\n-------------------------------------------\nAnd so on...",
      "jq -c '{\n  name: \"\\(.root_rgs | map(split(\"_\")[-1]) | join(\"_\")).json\",\n  content: {targets}\n}' input.json | while read -r json; do\n  jq '.content' <<< \"$json\" > \"$(jq -r '.name' <<< \"$json\")\"\ndone",
      "jq -r '\"cat\"\n  + \" >\\(.root_rgs | map(split(\"_\")[-1]) | join(\"_\")).json\"\n  + \" <<<\\({targets} | tojson | @sh)\"\n' input.json | bash",
      "jq -cr '(.root_rgs | \"\\(.[0]|sub(\"PROM_FD_\";\"\"))\\(.[1]|sub(\"PROM_JOB\";\"\"))\"),\n        {TARGETS: .targets}' input.json |\n  awk 'NR%2==1 {fn = $1 \".json\"; next} {print $0 >> fn}'"
    ],
    "utterance": "Create individual files for each object using values from the root_rgs array to name the file, and write the associated targets as a TARGETS object into that file.",
    "expressions": [
      "{\n  name: \"\\(.root_rgs | map(split(\"_\")[-1]) | join(\"_\")).json\",\n  content: {targets}\n}",
      "\"cat\"\n  + \" >\\(.root_rgs | map(split(\"_\")[-1]) | join(\"_\")).json\"\n  + \" <<<\\({targets} | tojson | @sh)\"",
      "(.root_rgs | \"\\(.[0]|sub(\"PROM_FD_\";\"\"))\\(.[1]|sub(\"PROM_JOB\";\"\"))\"),\n        {TARGETS: .targets}"
    ],
    "data": [
      {
        "input": [
          {
            "root_rgs": [
              "PROM_FD_ARCNA",
              "PROM_JOB_ICMP"
            ],
            "targets": [
              "HCC02155",
              "HCC09350",
              "HCC09321",
              "HCCEFACTORYWWW",
              "HCC9723"
            ]
          },
          {
            "root_rgs": [
              "PROM_FD_ARCNA",
              "PROM_JOB_WIN"
            ],
            "targets": [
              "LABTNSARWID236",
              "LABTNSARWID692",
              "VM00006"
            ]
          },
          {
            "root_rgs": [
              "PROM_FD_MTZ",
              "PROM_JOB_ICMP"
            ],
            "targets": [
              "TEIARWIN205",
              "TEIARWDB150",
              "TEIARWCXWA212"
            ]
          }
        ],
        "output": [
          {
            "ARCNA_ICMP.json": {
              "TARGETS": [
                "HCC02155",
                "HCC09350",
                "HCC09321",
                "HCCEFACTORYWWW",
                "HCC9723"
              ]
            }
          },
          {
            "ARCNA_WIN.json": {
              "TARGETS": [
                "LABTNSARWID236",
                "LABTNSARWID692",
                "VM00006"
              ]
            }
          }
        ]
      }
    ],
    "identifier": 70569726
  },
  {
    "context": [
      "What I would like to see is the backup.archive, backup.info, backup.label, backup.type, name combined in one simple structure, without getting into a cartesian product.",
      "where name is redundantly added to the list. How can I use jq to convert the shown input to the requested output?",
      "So, for each object in the top-level array you want to pull in `.name` into each of its `.backup` array's elements, right? Then try\njq 'map(.backup[] += {name} | del(.name))'"
    ],
    "utterance": "Augment each backup entry with its corresponding top-level name field so that each backup object contains an additional name property.",
    "expressions": [
      "map(.backup[] += {name} | del(.name))"
    ],
    "data": [
      {
        "input": [
          {
            "backup": [
              {
                "archive": {
                  "start": "000000090000000200000075",
                  "stop": "000000090000000200000075"
                },
                "info": {
                  "size": 1200934840
                },
                "label": "20220103-122051F",
                "type": "full"
              },
              {
                "archive": {
                  "start": "00000009000000020000007D",
                  "stop": "00000009000000020000007D"
                },
                "info": {
                  "size": 1168586300
                },
                "label": "20220103-153304F_20220104-081304I",
                "type": "incr"
              }
            ],
            "name": "dbname1"
          }
        ],
        "output": [
          {
            "backup": [
              {
                "archive": {
                  "start": "000000090000000200000075",
                  "stop": "000000090000000200000075"
                },
                "info": {
                  "size": 1200934840
                },
                "label": "20220103-122051F",
                "type": "full",
                "name": "dbname1"
              },
              {
                "archive": {
                  "start": "00000009000000020000007D",
                  "stop": "00000009000000020000007D"
                },
                "info": {
                  "size": 1168586300
                },
                "label": "20220103-153304F_20220104-081304I",
                "type": "incr",
                "name": "dbname1"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 70593955
  },
  {
    "context": [
      "is there a way to get just the `CidrIp` from each `json` element of this array?",
      "jq -r '.SecurityGroups[0].IpPermissions[0].IpRanges[].CidrIp'",
      "jq '.SecurityGroups[0].IpPermissions[0].IpRanges | values[].CidrIp'"
    ],
    "utterance": "Extract all CidrIp values from each object in the IpRanges array of the first IpPermissions item in the first SecurityGroups object.",
    "expressions": [
      ".SecurityGroups[0].IpPermissions[0].IpRanges[].CidrIp",
      ".SecurityGroups[0].IpPermissions[0].IpRanges | values[].CidrIp"
    ],
    "data": [
      {
        "input": {
          "SecurityGroups": [
            {
              "IpPermissions": [
                {
                  "IpRanges": [
                    {
                      "CidrIp": "11.22.33.44/32",
                      "Description": "Something"
                    },
                    {
                      "CidrIp": "22.33.44.12/32",
                      "Description": "Something else"
                    },
                    {
                      "CidrIp": "22.11.33.55/32",
                      "Description": "Something different"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          "11.22.33.44/32",
          "22.33.44.12/32",
          "22.11.33.55/32"
        ]
      }
    ],
    "identifier": 70598749
  },
  {
    "context": [
      "I have select by the value of a property, rather than by a numeric array index",
      "What i am trying to do is merge it under \"accounts\" and under \"name\": \"Retrieves the collection of Account resources.\"",
      "Fixed:\n\n```sh\njq -s '\n    ( .[1].item[] | select( .name == \"accounts\" ) | .item[] ) += .[0] | .[1]\n' jqtest.json collection.json\n```",
      "I find the following clearer (less mental overhead):\n\n```sh\njq -s '\n   .[0] as $to_insert |\n   .[1] | ( .item[] | select( .name == \"accounts\" ) | .item[] ) += $to_insert\n' jqtest.json collection.json\n```",
      "That said, I would avoid slurping in favour of `--argfile`.\n\n```sh\njq --argfile to_insert jqtest.json '\n    ( .item[] | select( .name == \"accounts\" ) | .item[] ) += $to_insert\n' collection.json\n```"
    ],
    "utterance": "Insert the event array from the first document under the object with name \"accounts\", and inside that, into the entry where name is \"Retrieves the collection of Account resources.\"",
    "expressions": [
      ".[0] as $to_insert | .[1] | ( .item[] | select( .name == \"accounts\" ) | .item[] ) += $to_insert",
      "( .[1].item[] | select( .name == \"accounts\" ) | .item[] ) += .[0] | .[1]",
      "( .item[] | select( .name == \"accounts\" ) | .item[] ) += $to_insert"
    ],
    "data": [
      {
        "input": [
          {
            "event": [
              {
                "listen": "test",
                "script": {
                  "exec": [],
                  "type": "text/javascript"
                }
              }
            ]
          },
          {
            "item": [
              {
                "name": "accounts",
                "item": [
                  {
                    "name": "Retrieves the collection of Account resources."
                  }
                ]
              },
              {
                "name": "accounts mapped",
                "item": [
                  {
                    "name": "Retrieves the collection of AccountMapped resources."
                  }
                ]
              }
            ]
          }
        ],
        "output": {
          "item": [
            {
              "name": "accounts",
              "item": [
                {
                  "name": "Retrieves the collection of Account resources.",
                  "event": [
                    {
                      "listen": "test",
                      "script": {
                        "exec": [],
                        "type": "text/javascript"
                      }
                    }
                  ]
                }
              ]
            },
            {
              "name": "accounts mapped",
              "item": [
                {
                  "name": "Retrieves the collection of AccountMapped resources."
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 70595878
  },
  {
    "context": [
      "My goal is to just ignore all items that have the taints `\"effect\": \"NoSchedule\"`",
      "jq '.items[]|select(.spec.taints[].effect!=\"NoSchedule\") '",
      "the item will be ignored if at least one taint with `effect` value `NoSchedule` exists.",
      ".items -= (.items | map(select(.spec.taints[].effect == \"NoSchedule\"))?)",
      "You can use `del` to delete the one(s) you intended :",
      "curl api | jq 'del(.items[] | select(.spec.taints[].effect == \"NoSchedule\")?)'"
    ],
    "utterance": "Return only those elements from the items array where none of the objects in spec.taints has an effect equal to NoSchedule.",
    "expressions": [
      ".items[] | select(.spec.taints[].effect != \"NoSchedule\")",
      ". as $in | $in * { items: $in.items | map(select(.spec.taints | all(.effect != \"NoSchedule\"))) }",
      ".items -= (.items | map(select(.spec.taints[].effect == \"NoSchedule\"))?)",
      "del(.items[] | select(.spec.taints[].effect == \"NoSchedule\")?)"
    ],
    "data": [
      {
        "input": {
          "kind": "NodeList",
          "apiVersion": "v1",
          "metadata": {
            "selfLink": "/api/v1/nodes",
            "resourceVersion": "8768"
          },
          "items": [
            {
              "metadata": {
                "name": "ip-101-191-101-101.ec2.internal",
                "selfLink": "/api/v1/nodes/ip-101-191-101-101.ec2.internal",
                "uid": "2l3kje2ili-23e232-2e3ee-edwed-232398h9e3h98h",
                "resourceVersion": "8768",
                "creationTimestamp": "2020-11-19T12:27:05Z"
              },
              "spec": {
                "podCIDR": "101.191.101.101/24",
                "providerID": "aws:///us-west-1e/i-lidss9jsjldsjli",
                "taints": [
                  {
                    "key": "worker-group",
                    "value": "prometheus",
                    "effect": "NoSchedule"
                  }
                ]
              }
            },
            {
              "metadata": {
                "name": "ip-101-191-101-101.ec2.internal",
                "selfLink": "/api/v1/nodes/ip-101-191-101-101.ec2.internal",
                "uid": "2l3kje2ili-23e232-2e3ee-edwed-232398h9e3h98h",
                "resourceVersion": "8768",
                "creationTimestamp": "2020-11-19T12:27:05Z"
              },
              "spec": {
                "podCIDR": "101.191.101.101/24",
                "providerID": "aws:///us-west-1e/i-lidss9jsjldsjli",
                "taints": [
                  {
                    "key": "worker-group",
                    "value": "prometheus",
                    "effect": "anyother"
                  }
                ]
              }
            },
            {
              "metadata": {
                "name": "ip-101-191-101-101.ec2.internal",
                "selfLink": "/api/v1/nodes/ip-101-191-101-101.ec2.internal",
                "uid": "2l3kje2ili-23e232-2e3ee-edwed-232398h9e3h98h",
                "resourceVersion": "8768",
                "creationTimestamp": "2020-11-19T12:27:05Z"
              },
              "spec": {
                "podCIDR": "101.191.101.101/24",
                "providerID": "aws:///us-west-1e/i-lidss9jsjldsjli",
                "taints": []
              }
            }
          ]
        },
        "output": [
          {
            "metadata": {
              "name": "ip-101-191-101-101.ec2.internal",
              "selfLink": "/api/v1/nodes/ip-101-191-101-101.ec2.internal",
              "uid": "2l3kje2ili-23e232-2e3ee-edwed-232398h9e3h98h",
              "resourceVersion": "8768",
              "creationTimestamp": "2020-11-19T12:27:05Z"
            },
            "spec": {
              "podCIDR": "101.191.101.101/24",
              "providerID": "aws:///us-west-1e/i-lidss9jsjldsjli",
              "taints": [
                {
                  "key": "worker-group",
                  "value": "prometheus",
                  "effect": "anyother"
                }
              ]
            }
          },
          {
            "metadata": {
              "name": "ip-101-191-101-101.ec2.internal",
              "selfLink": "/api/v1/nodes/ip-101-191-101-101.ec2.internal",
              "uid": "2l3kje2ili-23e232-2e3ee-edwed-232398h9e3h98h",
              "resourceVersion": "8768",
              "creationTimestamp": "2020-11-19T12:27:05Z"
            },
            "spec": {
              "podCIDR": "101.191.101.101/24",
              "providerID": "aws:///us-west-1e/i-lidss9jsjldsjli",
              "taints": []
            }
          }
        ]
      }
    ],
    "identifier": 70514746
  },
  {
    "context": [
      "I want to use `jq` to convert this to:\n{\n  \"key1\": {\n    \"innerkey\": \"value1\"\n  },\n  \"key2\": {\n    \"innerkey\": \"value2\"\n  },\n  \"key3\": {\n    \"innerkey\": \"value3\"\n  }\n}",
      "I want to apply a mapping to every value in the object, that converts `$value` to `{\"innerkey\": $value}`.",
      "It&#39;s literally called `map_values`. Use it like this\nmap_values({innerkey:.})",
      ".[] |= {innerkey:.}"
    ],
    "utterance": "Transform each value in the object to an object with a single key innerkey holding the original value.",
    "expressions": [
      "map_values({innerkey:.})",
      ".[] |= {innerkey:.}"
    ],
    "data": [
      {
        "input": {
          "key1": "value1",
          "key2": "value2",
          "key3": "value3"
        },
        "output": {
          "key1": {
            "innerkey": "value1"
          },
          "key2": {
            "innerkey": "value2"
          },
          "key3": {
            "innerkey": "value3"
          }
        }
      }
    ],
    "identifier": 70613566
  },
  {
    "context": [
      "Can I use jq to parse/filter this data? I would like to get all metrics on the `coredns` container:",
      "prom2json sample.prom | jq '\n  .[] | .metrics |= map(select(.labels.container==\"coredns\") )'\n'"
    ],
    "utterance": "Select all metrics where the container label is equal to coredns.",
    "expressions": [
      ".[] | .metrics |= map(select(.labels.container==\"coredns\"))"
    ],
    "data": [
      {
        "input": [
          {
            "name": "container_cpu_usage_seconds_total",
            "help": "[ALPHA] Cumulative cpu time consumed by the container in core-seconds",
            "type": "COUNTER",
            "metrics": [
              {
                "labels": {
                  "container": "coredns",
                  "namespace": "kube-system",
                  "pod": "coredns-64897985d-qzvj8"
                },
                "timestamp_ms": "1641411355244",
                "value": "1075.30302335"
              },
              {
                "labels": {
                  "container": "etcd",
                  "namespace": "kube-system",
                  "pod": "etcd-minikube"
                },
                "timestamp_ms": "1641411341787",
                "value": "7948.244422673"
              }
            ]
          },
          {
            "name": "container_memory_working_set_bytes",
            "help": "[ALPHA] Current working set of the container in bytes",
            "type": "GAUGE",
            "metrics": [
              {
                "labels": {
                  "container": "coredns",
                  "namespace": "kube-system",
                  "pod": "coredns-64897985d-qzvj8"
                },
                "timestamp_ms": "1641411355244",
                "value": "1.5364096e+07"
              },
              {
                "labels": {
                  "container": "etcd",
                  "namespace": "kube-system",
                  "pod": "etcd-minikube"
                },
                "timestamp_ms": "1641411341787",
                "value": "5.9752448e+07"
              }
            ]
          }
        ],
        "output": [
          {
            "name": "container_cpu_usage_seconds_total",
            "help": "[ALPHA] Cumulative cpu time consumed by the container in core-seconds",
            "type": "COUNTER",
            "metrics": [
              {
                "labels": {
                  "container": "coredns",
                  "namespace": "kube-system",
                  "pod": "coredns-64897985d-qzvj8"
                },
                "timestamp_ms": "1641411355244",
                "value": "1075.30302335"
              }
            ]
          },
          {
            "name": "container_memory_working_set_bytes",
            "help": "[ALPHA] Current working set of the container in bytes",
            "type": "GAUGE",
            "metrics": [
              {
                "labels": {
                  "container": "coredns",
                  "namespace": "kube-system",
                  "pod": "coredns-64897985d-qzvj8"
                },
                "timestamp_ms": "1641411355244",
                "value": "1.5364096e+07"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 70598827
  },
  {
    "context": [
      "jq -cr '.[] | \"\\(.key),\\(.user),\\(.path)\"' <<<$backups_to_perform",
      "while IFS=$'\\t' read -r key user path\ndo\n    # unescape TSV values\n    printf -v key  %b \"$key\"\n    printf -v user %b \"$user\"\n    printf -v path %b \"$path\"\n#   rsync_backup \"$key\" \"$user\" \"$path\"\n    echo \"key=$key user=$user path=$path\"\ndone < <(\n    jq -r '.[] | select(.key and .user and .path) | [.key,.user,.path] | @tsv' <<<$backups_to_perform\n)"
    ],
    "utterance": "Extract each object's key, user, and path fields as tab-separated values, only including objects where all three fields are present.",
    "expressions": [
      ".[] | \"\\(.key),\\(.user),\\(.path)\"",
      ".[] | select(.key and .user and .path) | [.key,.user,.path] | @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "__comment__": "comma in key value",
            "key": "key,1",
            "user": "user1",
            "path": "path1"
          },
          {
            "__comment__": "newline in key value",
            "key": "key\n2",
            "user": "user2",
            "path": "path2"
          },
          {
            "__comment__": "mispelled user attribute",
            "key": "key3",
            "usr": "user3",
            "path": "path3"
          },
          {
            "__comment__": "path containing ascii range [0x01-0x7f]",
            "key": "key4",
            "user": "user4",
            "path": "\u0001\u0002\u0003\u0004\u0005\u0006\u0007\b\t\n\u000b\f\r\u000e\u000f\u0010\u0011\u0012\u0013\u0014\u0015\u0016\u0017\u0018\u0019\u001a\u001b\u001c\u001d\u001e\u001f !\"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~\u007f"
          }
        ],
        "output": "key,1\tuser1\tpath1\nkey\n2\tuser2\tpath2\nkey4\tuser4\t\u0001\u0002\u0003\u0004\u0005\u0006\u0007\b\t\n\u000b\f\r\u000e\u000f\u0010\u0011\u0012\u0013\u0014\u0015\u0016\u0017\u0018\u0019\u001a\u001b\u001c\u001d\u001e\u001f !\"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~\u007f\n"
      }
    ],
    "identifier": 70604732
  },
  {
    "context": [
      "I am trying to use ``jq '.id'`` to parse the id from the json response.",
      "The error I get is :``jq: error (at <stdin>:0): Cannot index array with string \"id\"",
      "I understand that it should be ``jq '<arrayName> .id'`` to parse it. However, the response does not give any arrayName so I cannot use that method.",
      "then call that as\n```\njq '[].id'\n```"
    ],
    "utterance": "Extract the value of the id field from each object in a top-level array.",
    "expressions": [
      ".[].id"
    ],
    "data": [
      {
        "input": [
          {
            "id": 4738245,
            "project_id": 25486,
            "sha": "871c0484c3a7e72deea96fbcd48djdgh2",
            "ref": "",
            "status": "success",
            "created_at": "2022-01-06T04:44:40.372Z",
            "updated_at": "2022-01-06T04:50:36.663Z",
            "web_url": ""
          }
        ],
        "output": 4738245
      }
    ],
    "identifier": 70618659
  },
  {
    "context": [
      "My desired end state is a JSON file like this:\r\n```\r\n{\r\n   \"xxx\": null\r\n}\r\n```\r\nbut the command `jq --null-input --arg tst null '.xxx=$tst'` produces:\r\n```\r\n{\r\n  \"xxx\": \"null\"\r\n}\r\n```\r\n\r\nand `jq --null-input --arg tst \"\" '.xxx=$tst'` produces:\r\n```\r\n{\r\n  \"xxx\": \"\"\r\n}\r\n```\r\nHow can I pass a value that becomes the value `null` and not string `\"null\"`?",
      "Use `--argjson`, not `--arg`.",
      "$ jq --null-input --argjson tst null '.xxx=$tst'",
      "{\r\n  \"xxx\": null\r\n}",
      "`--arg` always treats the assigned value as a string, while `--argjson` treats it as a JSON value."
    ],
    "utterance": "Create an object with a key named xxx and value null using a variable or argument.",
    "expressions": [
      "jq --null-input --argjson tst null '.xxx=$tst'",
      "jq -n '{xxx: .}'",
      "echo null | jq '{xxx: .}'",
      "jq -n --argjson xxx null '{$xxx}'"
    ],
    "data": [
      {
        "input": null,
        "output": {
          "xxx": null
        }
      }
    ],
    "identifier": 70625307
  },
  {
    "context": [
      "My desired output is,\n{\n  \"student1\": {\n    \"Name\": \"Caroline\",\n    \"Age\": \"24\",\n    \"email\": \"Caroline123@gmail.com\",\n    \"Phone1\": \"1234567890\",\n    \"Phone2\": \"1267345980\",\n    \"Phone3\": \"9865432130\",\n    \"Blood group\": \"O+ve\"\n  }\n}",
      "The new key-value pairs **Phone1**, **Phone2** and **Phone3** , whose values are stored in the array called VALUES, needs to be added in the place of the key **Phone**",
      "and rename existing key `Phone` to `Phone1` by using\njq --sort-keys '.student1 += { \"Phone2\": \"1267345980\", \"Phone3\": \"9865432130\" }| .[] | .[\"Phone1\"] = .Phone | del(.Phone) | {\"Student1\" : . }'",
      "jq --sort-keys '.student1 += { \"Phone2\": \"1267345980\", \"Phone3\": \"9865432130\" }| .[] | .[\"Phone1\"] = .Phone | del(.Phone) | {\"Student1\" : . }'"
    ],
    "utterance": "Replace the key Phone with Phone1, and add Phone2 and Phone3 keys to student1, each with specified values.",
    "expressions": [
      ".student1 += { \"Phone2\": \"1267345980\", \"Phone3\": \"9865432130\" } | .student1[\"Phone1\"] = .student1.Phone | .student1 |= del(.Phone)"
    ],
    "data": [
      {
        "input": {
          "student1": {
            "Name": "Caroline",
            "Age": "24",
            "email": "Caroline123@gmail.com",
            "Phone": "1234567890",
            "Blood group": "O+ve"
          }
        },
        "output": {
          "student1": {
            "Name": "Caroline",
            "Age": "24",
            "email": "Caroline123@gmail.com",
            "Phone1": "1234567890",
            "Phone2": "1267345980",
            "Phone3": "9865432130",
            "Blood group": "O+ve"
          }
        }
      }
    ],
    "identifier": 70617932
  },
  {
    "context": [
      "I want it to be in 1 column and in pretty JSON format.",
      "jq -r '.Rules[] | [ (. | tostring) ] | @csv'",
      "But as @ZachYoung pointed out, as of now `jq` doesn't have any easy way to generate pretty strings with `tostring` or `tojson`.",
      "Personally I would stick to the compact version,"
    ],
    "utterance": "Output each object under the Rules array as a single compact string in one column of CSV format.",
    "expressions": [
      ".Rules[] | [ (. | tostring) ] | @csv"
    ],
    "data": [
      {
        "input": {
          "Rules": [
            {
              "Expiration": {
                "Days": 7
              },
              "ID": "Expire after 7 days",
              "Filter": {
                "Prefix": ""
              },
              "Status": "Enabled"
            },
            {
              "Expiration": {
                "Days": 1
              },
              "ID": "Remove after 1 day",
              "Filter": {},
              "Status": "Enabled"
            }
          ]
        },
        "output": [
          "\"{\"Expiration\":{\"Days\":7},\"ID\":\"Expire after 7 days\",\"Filter\":{\"Prefix\":\"\"},\"Status\":\"Enabled\"}\"",
          "\"{\"Expiration\":{\"Days\":1},\"ID\":\"Remove after 1 day\",\"Filter\":{},\"Status\":\"Enabled\"}\""
        ]
      }
    ],
    "identifier": 70627285
  },
  {
    "context": [
      "But in my case, I'm starting with X and Z and want to calculate Y (such that X * Y = Z). If we only have objects with scalar properties, then `jq X + Y` equals `Z`, and we can also calculate `Y` as `jq Z - X`. However, this fails if X or Y contain properties with object values such as in the above example:",
      "Is there an elegant solution to this problem with jq?",
      "def remove($o2):\n   reduce ( to_entries[] | [ .key, .value ] ) as [ $k, $v1 ] (\n      {};\n      if $o2 | has($k) | not then\n         # Keep existing value if $o2 doesn't have the key.\n         .[$k] = $v1\n      else\n         $o2[$k] as $v2 |\n         if $v1 | type == \"object\" then\n            # We're comparing objects.\n            ( $v1 | remove($o2[$k]) ) as $v_diff |\n            if $v_diff | length == 0 then\n               # Discard identical values.\n               .\n            else\n               # Keep the differences of the values.\n               .[$k] = $v_diff\n            end\n         else\n            # We're comparing non-objects.\n            if $v1 == $v2 then\n               # Discard identical values.\n               .\n            else\n               # Keep existing value if different.\n               .[$k] = $v1\n            end\n         end\n      end\n   );",
      ". as [ $Z, $X ] | $Z | remove($X)",
      "def sub($v2):\n   (       type ) as $t1 |\n   ( $v2 | type ) as $t2 |\n   if $t1 == $t2 then\n      if $t1 == \"object\" then\n         with_entries(\n            .key as $k |\n            .value = (\n               .value |\n               if $v2 | has($k) then sub( $v2[$k] ) else . end\n            )\n         ) |\n         select( length != 0 )\n      else\n         select( . != $v2 )\n      end\n   else\n      .\n   end;",
      ". as [ $Z, $X ] | $Z | sub($X)"
    ],
    "utterance": "Given two multi-level objects X and Z, find the minimal object Y such that merging X and Y produces Z, handling nested objects correctly.",
    "expressions": [
      "def remove($o2):\n   reduce ( to_entries[] | [ .key, .value ] ) as [ $k, $v1 ] (\n      {};\n      if $o2 | has($k) | not then\n         .[$k] = $v1\n      else\n         $o2[$k] as $v2 |\n         if $v1 | type == \"object\" then\n            ( $v1 | remove($o2[$k]) ) as $v_diff |\n            if $v_diff | length == 0 then\n               .\n            else\n               .[$k] = $v_diff\n            end\n         else\n            if $v1 == $v2 then\n               .\n            else\n               .[$k] = $v1\n            end\n         end\n      end\n   );\n\n. as [ $Z, $X ] | $Z | remove($X)",
      "def sub($v2):\n   (       type ) as $t1 |\n   ( $v2 | type ) as $t2 |\n   if $t1 == $t2 then\n      if $t1 == \"object\" then\n         with_entries(\n            .key as $k |\n            .value = (\n               .value |\n               if $v2 | has($k) then sub( $v2[$k] ) else . end\n            )\n         ) |\n         select( length != 0 )\n      else\n         select( . != $v2 )\n      end\n   else\n      .\n   end;\n\n. as [ $Z, $X ] | $Z | sub($X)"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1,
            "b": 5,
            "c": {
              "a": 3
            }
          },
          {
            "a": 3,
            "b": 5,
            "c": {
              "a": 3,
              "x": 10,
              "y": 11
            },
            "d": 2
          }
        ],
        "output": {
          "a": 3,
          "c": {
            "x": 10,
            "y": 11
          },
          "d": 2
        }
      }
    ],
    "identifier": 70610489
  },
  {
    "context": [
      "I want to merge two json arrays with help of `jq`. Each object in arrays contains name field, which allow me to group by and merge two arrays into one.",
      "Desired Output",
      "[\n  {\n    \"name\": \"power_branch\",\n    \"description\": \"master\",\n    \"runner\": \"power\",\n    \"runner_tag\": \"macos\"\n  },\n  {\n    \"name\": \"power_branch\",\n    \"description\": \"master\",\n    \"runner\": \"power\",\n    \"runner_tag\": \"ubuntu\"\n  },\n  {\n    \"name\": \"test_branch\",\n    \"description\": \"main\",\n    \"runner\": \"tester\",\n    \"runner_tag\": \"\"\n  }\n]",
      "I tried with following script, but power_branch entry was override, instead i want another entry with different runner_tag",
      "you could read in the latter (runners) as a variable using --argjson and append to each element of the input array (labels) using map the corresponding fields determined by select.",
      "map(.name as $name | . + ($runners[] | select(.name == $name)))",
      "instead of using [command substitution](https://www.gnu.org/software/bash/manual/html_node/Command-Substitution.html) \"$(\u2026)\"..., you could read in the runners file directly using either --slurpfile... or ... using --argfile",
      "map(.name as $name | . + ($runners[][] | select(.name == $name)))",
      "map(.name as $name | . + ($runners[] | select(.name == $name)))",
      "using input for each file together with the -n option. Note that this requires the two files to be provided in this exact order as they are being read in sequentially.",
      "jq -n 'input as $runners | input |\n  map(.name as $name | . + ($runners[] | select(.name == $name)))\n' runners.json labels.json",
      "jq 'input as $runners |\n  map(.name as $name | . + ($runners[] | select(.name == $name)))\n' runners.json labels.json",
      "here's yet another approach using the [SQL-style operators](https://stedolan.github.io/jq/manual/v1.6/#SQL-StyleOperators) INDEX and JOIN",
      "jq '\n  JOIN(INDEX(input[]; .name); .name) | map(select(.[1]) | add)\n' runners.json labels.json"
    ],
    "utterance": "Combine two arrays by matching objects with the same name field and merge their keys so that all runner entries are preserved for matching names.",
    "expressions": [
      "map(.name as $name | . + ($runners[] | select(.name == $name)))",
      "map(.name as $name | . + ($runners[][] | select(.name == $name)))",
      "input as $runners | input | map(.name as $name | . + ($runners[] | select(.name == $name)))",
      "input as $runners | map(.name as $name | . + ($runners[] | select(.name == $name)))",
      "JOIN(INDEX(input[]; .name); .name) | map(select(.[1]) | add)"
    ],
    "data": [
      {
        "input": {
          "labels": [
            {
              "name": "power_branch",
              "description": "master"
            },
            {
              "name": "test_branch",
              "description": "main"
            }
          ],
          "runners": [
            {
              "name": "power_branch",
              "runner": "power",
              "runner_tag": "macos"
            },
            {
              "name": "power_branch",
              "runner": "power",
              "runner_tag": "ubuntu"
            },
            {
              "name": "test_branch",
              "runner": "tester",
              "runner_tag": ""
            },
            {
              "name": "development",
              "runner": "dev",
              "runner_tag": "ubuntu"
            }
          ]
        },
        "output": [
          {
            "name": "power_branch",
            "description": "master",
            "runner": "power",
            "runner_tag": "macos"
          },
          {
            "name": "power_branch",
            "description": "master",
            "runner": "power",
            "runner_tag": "ubuntu"
          },
          {
            "name": "test_branch",
            "description": "main",
            "runner": "tester",
            "runner_tag": ""
          }
        ]
      }
    ],
    "identifier": 70567330
  },
  {
    "context": [
      "Previously, we would extract the whole portion of \"items\" using jq with a very straightforward command (which worked fine):",
      "cat file.json | jq '.items' > file.items.json",
      "However, recently the size of the original json file has increased drastically in size, causing the script to fail due to a **Out of memory** error. One obvious solution is to use jq's 'stream' option.",
      "You should use the `--stream` flag in combination with the `fromstream` builtin",
      "jq --stream --null-input '\n  fromstream(inputs | select(.[0][0] == \"items\"))[]\n' file.json",
      "If a stream of the {code, name, prices} objects is acceptable, then you could go with:",
      "< input.json jq --stream -n '\n   fromstream( 2 | truncate_stream(inputs | select(.[0][0] == \"items\")) )'"
    ],
    "utterance": "Extract the contents of the top-level 'items' key from a large file using a streaming approach to avoid memory errors.",
    "expressions": [
      "fromstream(inputs | select(.[0][0] == \"items\"))[]",
      "fromstream(2 | truncate_stream(inputs | select(.[0][0] == \"items\")))"
    ],
    "data": [
      {
        "input": {
          "version": null,
          "produced": "2021-01-01T00:00:00+0000",
          "other": "content here",
          "items": [
            {
              "code": "AA",
              "name": "Example 1",
              "prices": [
                "other",
                "content",
                "here"
              ]
            },
            {
              "code": "BB",
              "name": "Example 2",
              "prices": [
                "other",
                "content",
                "here"
              ]
            }
          ]
        },
        "output": [
          {
            "code": "AA",
            "name": "Example 1",
            "prices": [
              "other",
              "content",
              "here"
            ]
          },
          {
            "code": "BB",
            "name": "Example 2",
            "prices": [
              "other",
              "content",
              "here"
            ]
          }
        ]
      }
    ],
    "identifier": 70623635
  },
  {
    "context": [
      "Would like to SLICE a huge json file ~20GB into smaller chunk of data based on array size (10000/50000 etc)..",
      "Expected Output: for Slice of 2 objects in array",
      "{... , \"add\":[{\"rngNum\":\"1\", ...},{\"rngNum\":\"2\", ...}]}",
      "{... , \"add\":[{\"rngNum\":\"3\", ...},{\"rngNum\":\"4\", ...}]}",
      "In this response, which calls jq just once, I&#39;m going to assume your computer has enough memory to read the entire JSON.",
      "Assuming a chunk size of 2, and that the output files are to be named using the template part-N.json, you could write:",
      "< input.json jq -r --argjson size 2 '\n  del(.add) as $object\n  | (.add|_nwise($size) | (\"\\t\", $object + {add:.} ))\n' | awk '\n      /^\\t/ {fn++; next}\n      { print >> \"part-\" fn \".json\"}'",
      "The following assumes the input JSON is too large to read into memory and therefore uses jq's `--stream` command-line option.",
      "I'll focus on the \"slicing\"  of the `.add` array, ...",
      "< input.json jq -nc --stream --argjson size 2 '\n  def regroup(stream; $n):\n    foreach (stream, null) as $x ({a:[]};\n      if $x == null then .emit = .a\n      elif .a|length == $n then .emit = .a | .a = [$x]\n      else .emit=null | .a += [$x] end;\n      select(.emit).emit);\n\n    regroup(fromstream( 2 | truncate_stream(inputs | select(.[0][0] == \"add\")) );\n            $size)' |\n  awk '{fn++; print > fn \".json\"}'"
    ],
    "utterance": "Split a large file by dividing the 'add' array into smaller arrays of a specified size, producing separate outputs for each chunk.",
    "expressions": [
      "del(.add) as $object | (.add|_nwise($size) | (\"\\t\", $object + {add:.} ))",
      "def regroup(stream; $n): foreach (stream, null) as $x ({a:[]}; if $x == null then .emit = .a elif .a|length == $n then .emit = .a | .a = [$x] else .emit=null | .a += [$x] end; select(.emit).emit); regroup(fromstream( 2 | truncate_stream(inputs | select(.[0][0] == \"add\")) ); $size)"
    ],
    "data": [
      {
        "input": {
          "recDt": "2021-01-05",
          "country": "US",
          "name": "ABC",
          "number": "9828",
          "add": [
            {
              "evnCd": "O",
              "rngNum": "1",
              "state": "TX",
              "city": "ANDERSON",
              "postal": "77830"
            },
            {
              "evnCd": "O",
              "rngNum": "2",
              "state": "TX",
              "city": "ANDERSON",
              "postal": "77832"
            },
            {
              "evnCd": "O",
              "rngNum": "3",
              "state": "TX",
              "city": "ANDERSON",
              "postal": "77831"
            },
            {
              "evnCd": "O",
              "rngNum": "4",
              "state": "TX",
              "city": "ANDERSON",
              "postal": "77834"
            }
          ]
        },
        "output": [
          {
            "recDt": "2021-01-05",
            "country": "US",
            "name": "ABC",
            "number": "9828",
            "add": [
              {
                "rngNum": "1",
                "state": "TX",
                "city": "ANDERSON",
                "postal": "77830"
              },
              {
                "rngNum": "2",
                "state": "TX",
                "city": "ANDERSON",
                "postal": "77832"
              }
            ]
          },
          {
            "recDt": "2021-01-05",
            "country": "US",
            "name": "ABC",
            "number": "9828",
            "add": [
              {
                "rngNum": "3",
                "state": "TX",
                "city": "ANDERSON",
                "postal": "77831"
              },
              {
                "rngNum": "4",
                "state": "TX",
                "city": "ANDERSON",
                "postal": "77834"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 70627447
  },
  {
    "context": [
      "Now I want to go through the results and e.g. in case, onlineScore drops below 0.9 (or suspensionScore resp. auditScore below 1.0, I want to create a text alert, which also includes the satelliteName. Example: auditScore below threshold: 0.98 for us2.storj.io",
      "jq -r '.audits | \n\t(select(.auditScore < 1) | \"auditScore below threshold: \\(.auditScore) for \\(.satelliteName)\"),\n\t(select(.suspensionScore < 1) | \"suspensionScore below threshold: \\(.suspensionScore) for \\(.satelliteName)\"),\n\t(select(.onlineScore < 1) | \"onlineScore below threshold: \\(.onlineScore) for \\(.satelliteName)\")\n'",
      "for sat in `docker exec -i storagenode wget -qO - localhost:14002/api/sno | jq .satellites[].id -r` do\ndocker exec -i storagenode wget -qO - localhost:14002/api/sno/satellite/$sat \\\n| jq --raw-output \\\n  --argjson auditThreshold 1 \\\n  --argjson suspensionThreshold 1 \\\n  --argjson onlineThreshold 1 \\\n  '.audits\n    | .satelliteName as $name\n    | (\n        [{auditScore}, $auditThreshold],\n        [{suspensionScore}, $suspensionThreshold],\n        [{onlineScore}, $onlineThreshold]\n      )\n    | select(.[0][] < .[1])\n    | \"\\(.[0] | keys[]) (\\(.[0][])) below threshold (\\(.[1])) for \\($name)\"\n  '\ndone",
      "There is a result for http://localhost:14002/api/sno/satellites ... 'audits': [{ 'auditScore': 1, 'suspensionScore': 1, 'onlineScore': 0.99743587, 'satelliteName': 'us2.storj.io:7777' }, ... ]"
    ],
    "utterance": "Output an alert for each satellite where onlineScore is below 0.9, auditScore is below 1.0, or suspensionScore is below 1.0, including the actual value and the satelliteName.",
    "expressions": [
      ".audits | (select(.auditScore < 1) | \"auditScore below threshold: \\(.auditScore) for \\(.satelliteName)\"), (select(.suspensionScore < 1) | \"suspensionScore below threshold: \\(.suspensionScore) for \\(.satelliteName)\"), (select(.onlineScore < 0.9) | \"onlineScore below threshold: \\(.onlineScore) for \\(.satelliteName)\")",
      ".audits | .satelliteName as $name | ( [{auditScore}, 1.0], [{suspensionScore}, 1.0], [{onlineScore}, 0.9] ) | select(.[0][] < .[1]) | \"\\(.[0] | keys[]) (\\(.[0][])) below threshold (\\(.[1])) for \\($name)\""
    ],
    "data": [
      {
        "input": {
          "audits": [
            {
              "auditScore": 0.98,
              "suspensionScore": 1.0,
              "onlineScore": 0.92,
              "satelliteName": "us2.storj.io:7777"
            },
            {
              "auditScore": 1.0,
              "suspensionScore": 0.98,
              "onlineScore": 0.85,
              "satelliteName": "eu1.storj.io:7777"
            },
            {
              "auditScore": 1.0,
              "suspensionScore": 1.0,
              "onlineScore": 0.995,
              "satelliteName": "saltlake.tardigrade.io:7777"
            }
          ]
        },
        "output": [
          "auditScore below threshold: 0.98 for us2.storj.io:7777",
          "suspensionScore below threshold: 0.98 for eu1.storj.io:7777",
          "onlineScore below threshold: 0.85 for eu1.storj.io:7777"
        ]
      }
    ],
    "identifier": 70564184
  }
]