[
  {
    "context": [
      "I want to copy the block from foo.json to bar.json in one line so bar.json looks like this:",
      "jq ' . + ( input | {block} )' bar.json foo.json | sponge bar.json"
    ],
    "utterance": "Add the 'block' key and its value from foo.json to bar.json, updating bar.json in place.",
    "expressions": [
      ". + (input | {block})"
    ],
    "data": [
      {
        "input": {
          "bar.json": {
            "name": "bar"
          },
          "foo.json": {
            "name": "foo",
            "block": {
              "one": 1,
              "two": "2"
            },
            "otherData": {
              "two": 1,
              "one": "2"
            }
          }
        },
        "output": {
          "name": "bar",
          "block": {
            "one": 1,
            "two": "2"
          }
        }
      }
    ],
    "identifier": 73049337
  },
  {
    "context": [
      "How do i return exit status code from `jq` instead of true/false. Currently `jq` is returning true or false hence grep is considering everything as match.",
      "By using the `-e` command line switch.",
      "`-e` / `--exit-status:`\n\nSets the exit status of jq to 0 if the last output values was neither `false` nor `null`, 1 if the last output value was either `false` or `null`, or 4 if no valid result was ever produced.",
      "Redirect the output (e.g. using `>/dev/null`) if you don't want to see the output."
    ],
    "utterance": "Return a success (0) exit code if the condition is true and a non-zero exit code if the condition is false, without printing true or false as output.",
    "expressions": [
      "jq -e '<your-filter>' >/dev/null"
    ],
    "identifier": 73042446
  },
  {
    "context": [
      "I am trying to change the \".\" (period) character to a \"-\" (hyphen) in the `name` field.",
      "Sample JSON:\n[\n    {\"id\":\"1\",\"name\":\"a.a\"},\n    {\"id\":\"2\",\"name\":\"b.b\"},\n    {\"id\":\"3\",\"name\":\"c.c\"}\n]",
      "Expected Output:\n[\n    {\"id\":\"1\",\"name\":\"a-a\"},\n    {\"id\":\"2\",\"name\":\"b-b\"},\n    {\"id\":\"3\",\"name\":\"c-c\"}\n]",
      "To replace a dot with a dash, use the `sub` function:",
      "jq '.[].name |= sub(\"\\.\", \"-\")' file.json"
    ],
    "utterance": "Replace every period in the name field with a hyphen for each object in the array.",
    "expressions": [
      ".[].name |= sub(\"\\\\.\", \"-\")"
    ],
    "data": [
      {
        "input": [
          {
            "id": "1",
            "name": "a.a"
          },
          {
            "id": "2",
            "name": "b.b"
          },
          {
            "id": "3",
            "name": "c.c"
          }
        ],
        "output": [
          {
            "id": "1",
            "name": "a-a"
          },
          {
            "id": "2",
            "name": "b-b"
          },
          {
            "id": "3",
            "name": "c-c"
          }
        ]
      }
    ],
    "identifier": 73064061
  },
  {
    "context": [
      "When I run explode and then through implode, I am expecting it to return the same string. But it is not.",
      "JQ: '@base64d | explode | implode | @base64'",
      "Output: \"AQEAAAABAQAyGWRkZBXvv71bBwAAAAABAgMEBQYHCAkKUgbvv70/Ugbvv70/\"",
      "Debugging further, ",
      "@base64d | explode | .[14]",
      "returns",
      "65533",
      "jq expects the string encoded with base64 to be text encoded with UTF-8.",
      "\"If the decoded string is not UTF-8, the results are undefined.\"",
      "Your input is not UTF-8."
    ],
    "utterance": "Round-trip a non-UTF-8 base64-encoded binary string through decoding, explode, implode, and encoding, expecting the output to match the original input.",
    "expressions": [
      "@base64d | explode | implode | @base64"
    ],
    "data": [
      {
        "input": "\"AQEAAAABAQAyGWRkZBXNWwcAAAAAAQIDBAUGBwgJClIGnj9SBp4/\"",
        "output": "\"AQEAAAABAQAyGWRkZBXvv71bBwAAAAABAgMEBQYHCAkKUgbvv70/Ugbvv70/\""
      }
    ],
    "identifier": 73031151
  },
  {
    "context": [
      "I can extract the runtime info using this",
      "# jq -r '.result.software .runc' input.json",
      "However, if I try to extract the version number dynamically, it does not work (The runtime can change)",
      "# runtime=$(jq -r '.result.run .runtime' input.json)",
      "# jq --arg key \"$runtime\" '.result.software .[$key]'",
      "The combined dot notation only works with literal names. Use `.result.software[$key]` instead:",
      "jq -r --arg key \"$runtime\" '.result.software[$key]'",
      "If the dynamic value is always a result of evaluating the same JSON file, and you don't need that value elsewhere in the shell script, you can resolve that internally and reduce the script to just one call to jq:",
      "jq -r '.result.run.runtime as $key | .result.software[$key]' input.json",
      "Or without using variables at all:",
      "jq -r '.result | .software[.run.runtime]' input.json"
    ],
    "utterance": "Extract the version from result.software whose key matches result.run.runtime, with the key determined dynamically.",
    "expressions": [
      ".result.software[$key]",
      ".result.run.runtime as $key | .result.software[$key]",
      ".result | .software[.run.runtime]"
    ],
    "data": [
      {
        "input": {
          "result": {
            "run": {
              "runtime": "runc"
            },
            "software": {
              "runc": "1.1.2",
              "kata": "1.3.7"
            }
          }
        },
        "output": "1.1.2"
      }
    ],
    "identifier": 73033155
  },
  {
    "context": [
      "I have a usecase to add a feild which is in a different level of the JSON to a object.",
      "{metadata : .metadata+= {\"operation\":.materialFiles[0].type}, systemName }",
      "Use parentheses and don&#39;t update:\n~~~sh\n{metadata: (.metadata + {\"operation\":.materialFiles[0].type}), systemName, priority}\n~~~",
      "Or just alter `.metadata` and `del`ete `.materialFiles`:\n~~~sh\n.metadata+= {\"operation\":.materialFiles[0].type} | del(.materialFiles)\n~~~"
    ],
    "utterance": "Add a field named operation with the value from the first element's type property in materialFiles to the metadata object, preserving all other fields including priority and systemName.",
    "expressions": [
      "{metadata: (.metadata + {\"operation\": .materialFiles[0].type}), systemName, priority}",
      ".metadata+= {\"operation\": .materialFiles[0].type} | del(.materialFiles)"
    ],
    "data": [
      {
        "input": {
          "metadata": {
            "ItemName": "Arun 101",
            "fullflow": "true",
            "name": "arunkumar",
            "code": "12345"
          },
          "systemName": "Super Jack",
          "priority": "Rush",
          "materialFiles": [
            {
              "type": "packaging_metadata"
            }
          ]
        },
        "output": {
          "metadata": {
            "ItemName": "Arun 101",
            "fullflow": "true",
            "name": "arunkumar",
            "code": "12345",
            "operation": "packaging_metadata"
          },
          "systemName": "Super Jack",
          "priority": "Rush"
        }
      }
    ],
    "identifier": 73070741
  },
  {
    "context": [
      "Output required after applying JQ filter:\r\n\r\n      {\r\n      \"msg\": \"Details fetched successfully\",\r\n      \"status\": 1,\r\n      \"details\": {\r\n          \"a\": {\r\n            \"amount\": 2500,\r\n            \"pre\": [\r\n              \"11\",\r\n              \"429393\",\r\n              \"543216\",\r\n              \"987657\"\r\n            ]\r\n          },\r\n          \"b\": {\r\n            \"amount\": 1500,\r\n            \"pre\": [\r\n              \"480855\"\r\n            ]\r\n          },\r\n          \"c\": {\r\n            \"amount\": 0,\r\n            \"pre\": [\r\n              \"No data present\"\r\n            ]\r\n          },\r\n          \"d\": {\r\n            \"amount\": 1500,\r\n            \"pre\": [\r\n              \"526702\"\r\n            ]\r\n          },\r\n          \"e\": {\r\n            \"amount\": 2500,\r\n            \"pre\": [\r\n              \"No data present\"\r\n            ]\r\n          }\r\n      }\r\n    }",
      "I tried using the below JQ filter but I am getting \"details\" as array but \"details\" is object in final output.",
      "To delete the `test` field from the result, use `map_values` with `del` on the resulting object:\r\n~~~sh\r\njq '.details |= (INDEX(.test) | map_values(del(.test)))'\r\n~~~"
    ],
    "utterance": "Convert the 'details' array into an object keyed by the 'test' field, and remove the 'test' field from each object while keeping 'amount' and 'pre'.",
    "expressions": [
      ".details |= (INDEX(.test) | map_values(del(.test))) | {msg: .message, status: .status, details: .details}"
    ],
    "data": [
      {
        "input": {
          "message": "Details fetched successfully",
          "status": 1,
          "details": [
            {
              "test": "a",
              "amount": 2500.0,
              "pre": [
                "11",
                "429393",
                "543216",
                "987657"
              ]
            },
            {
              "test": "b",
              "amount": 1500.0,
              "pre": [
                "480855"
              ]
            },
            {
              "test": "c",
              "amount": 0.0,
              "pre": [
                "No data present"
              ]
            },
            {
              "test": "d",
              "amount": 1500.0,
              "pre": [
                "526702"
              ]
            },
            {
              "test": "e",
              "amount": 2500.0,
              "pre": [
                "No data present"
              ]
            }
          ]
        },
        "output": {
          "msg": "Details fetched successfully",
          "status": 1,
          "details": {
            "a": {
              "amount": 2500,
              "pre": [
                "11",
                "429393",
                "543216",
                "987657"
              ]
            },
            "b": {
              "amount": 1500,
              "pre": [
                "480855"
              ]
            },
            "c": {
              "amount": 0,
              "pre": [
                "No data present"
              ]
            },
            "d": {
              "amount": 1500,
              "pre": [
                "526702"
              ]
            },
            "e": {
              "amount": 2500,
              "pre": [
                "No data present"
              ]
            }
          }
        }
      }
    ],
    "identifier": 73048140
  },
  {
    "context": [
      "How can I pipe `jq` to the output of `getInstances()` so that it will parse the JSON and return the number of instances inside the nested JSON array? For example, in the above output, there are 2 \"instances\" inside the nested JSON array.",
      ".[0]|length\n\nwould suffice, but is not very robust against a violation of assumptions."
    ],
    "utterance": "Count the number of objects inside the inner array of a double-nested array structure.",
    "expressions": [
      ".[0] | length"
    ],
    "data": [
      {
        "input": [
          [
            {
              "id": 193932,
              "name": "foobaz"
            },
            {
              "id": 28348,
              "name": "fizzbuzz"
            }
          ]
        ],
        "output": 2
      }
    ],
    "identifier": 73081424
  },
  {
    "context": [
      "What changes should I make in the jq command so that it appends _IMAGE for value parsed from **image-name** key and _VERSION for value parsed from **image-tag** key. Output should look something like this:\n```\n_IMAGE test-broker\n_VERSION master-v2\n_IMAGE test-service-provider\n_VERSION master-v2\n\n```",
      "You can just define another prefix and reorder:\n```\njq -r --arg prefix1 \"_IMAGE \" --arg prefix2 \"_VERSION \"  '\n  .. | objects | select(has(\"image-name\")) |\n  ($prefix1 + .\"image-name\", $prefix2 + .\"image-tag\")\n' image-data.json\n```"
    ],
    "utterance": "Output each image-name value prefixed with _IMAGE and each image-tag value prefixed with _VERSION, preserving their association and order for all image objects.",
    "expressions": [
      "--arg prefix1 \"_IMAGE \" --arg prefix2 \"_VERSION \" '.. | objects | select(has(\"image-name\")) | ($prefix1 + .\"image-name\", $prefix2 + .\"image-tag\")'"
    ],
    "data": [
      {
        "input": {
          "appsol": {
            "test": {
              "repository": "https://github.com/App/test.git",
              "test-broker": {
                "commit": "",
                "image-tag": "master-v2",
                "image-name": "test-broker",
                "image-repository": "us.gcr.io",
                "image-namespace": "ap-cloud"
              },
              "test-service-provider": {
                "commit": "",
                "image-tag": "master-v2",
                "image-name": "test-service-provider",
                "image-repository": "us.gcr.io",
                "image-namespace": "ap-cloud"
              }
            }
          }
        },
        "output": "_IMAGE test-broker\n_VERSION master-v2\n_IMAGE test-service-provider\n_VERSION master-v2"
      }
    ],
    "identifier": 73066235
  },
  {
    "context": [
      "since the element has pattern \"key/values\" where only values part differ I want to reduce the output to something like this \n```\n{ \"public-policy-routing\" : [0,1,5,7,10] }\n```",
      "One way would be using `reduce` on the array elements. Split at the slash, destructure the resulting array into a key and value variable, then add the value as an array to the field with the key name:\n~~~sh\njq 'reduce (.[]/\"/\") as [$k,$v] ({}; .[$k] += [$v])'\n~~~",
      "If you wanted numbers instead of strings, convert the values using `tonumber`:\n~~~sh\njq 'reduce (.[]/\"/\") as [$k,$v] ({}; .[$k] += [$v | tonumber])'\n~~~",
      "Here is a robust solution that works with arbitrary strings by [grouping them][1]:\n\n```\nmap(. / \"/\") | group(first) | map_values(map(last|tonumber))\n```"
    ],
    "utterance": "Extract the shared prefix before '/' as the key and collect all numeric suffixes as an array of numbers under that key.",
    "expressions": [
      "reduce (.[]/\"/\") as [$k,$v] ({}; .[$k] += [$v | tonumber])",
      "map(. / \"/\") | group(first) | map_values(map(last|tonumber))"
    ],
    "data": [
      {
        "input": [
          "public-policy-routing/0",
          "public-policy-routing/1",
          "public-policy-routing/5",
          "public-policy-routing/7",
          "public-policy-routing/10"
        ],
        "output": {
          "public-policy-routing": [
            0,
            1,
            5,
            7,
            10
          ]
        }
      }
    ],
    "identifier": 73072017
  },
  {
    "context": [
      "I have the following JSON object:",
      "Using `jq`, I want to print the following to standard output:",
      "attacks:",
      "- name: normal fist",
      "  type: melee",
      "  damage: 3",
      "- name: thunder fist",
      "  damage: 5",
      "  attributes:",
      "    electrical",
      "I only want the \"attributes\" key to be printed under the \"thunder fist\" entry. I can't figure out how to make the printing of that portion conditional.",
      "jq -r '.[] | .attack + if .attributes then .attributes[] else \"\" end'"
    ],
    "utterance": "Output each attack as a block with its name, type, and damage; if attributes are present, include them as a nested list under the corresponding attack.",
    "expressions": [
      "keys_unsorted[] as $k\n| ($k + \":\"),\n  (.[$k] as $o\n  | ($o|keys_unsorted[]) as $k1\n  | (\"-name: \" + $k1), ($o[$k1] | if type == \"array\" then (\"  attributes:\", (.[] | \"    \" + .)) else (\"  \" + $k1 + \": \" + tostring) end ) )"
    ],
    "data": [
      {
        "input": {
          "attacks": {
            "normal fist": {
              "type": "melee",
              "damage": 3
            },
            "thunder fist": {
              "type": "melee",
              "damage": 5,
              "attributes": [
                "electrical"
              ]
            }
          }
        },
        "output": "attacks:\n-name: normal fist\n  type: melee\n  damage: 3\n-name: thunder fist\n  type: melee\n  damage: 5\n  attributes:\n    electrical"
      }
    ],
    "identifier": 73074032
  },
  {
    "context": [
      "I am trying to copy certain `key:value` pairs from a `json` file to normal text file using `jq` within a `bash` script.",
      "But this copies only \"values\" (only values of .abc and .xyz) to test_sample.txt. But I am expecting:",
      "cat test_sample.txt\nX=test1\nY=test2",
      "If I understood correctly, you want to convert a JSON object's fields to raw text, following a `key=value` structure.",
      "Use `to_entries` to decompose the object, iterate over its items with `[]`, and output a formatted string using `.key` and `.value`. Make sure the output is raw text using `-r`:",
      "jq -r 'to_entries[] | \"\\(.key)=\\(.value)\"' config_test.json > test_sample.txt"
    ],
    "utterance": "Output each top-level key and value as key=value lines in a text file, one per line.",
    "expressions": [
      "jq -r 'to_entries[] | \"\\(.key)=\\(.value)\"' config_test.json"
    ],
    "data": [
      {
        "input": {
          "abc": "test1",
          "xyz": "test2"
        },
        "output": "abc=test1\nxyz=test2"
      }
    ],
    "identifier": 73111875
  },
  {
    "context": [
      "We're taking in a list of strings of the form: `field:<VALUE>`, where `<VALUE>` can be either `''` (empty), or one or more characters.",
      "The objective is to return: `NULL` if `<VALUE>` is `''` (empty), or `value=<VALUE>` if non-empty.",
      "The closest you can get to a \"conditional substitution\" within `sub` would be along these lines:",
      "sub( \"^field:(?<val>.*)$\" ; \"value=\\(.val | if length==0 then \\\"NULL\\\" else . end )\" )",
      "sub( \"^(field:(?<val>.+)|field:)$\" ; \"value=\\(.val // \\\"NULL\\\")\" )"
    ],
    "utterance": "For each input line in the form 'field:<VALUE>', return 'value=<VALUE>' if <VALUE> is non-empty, or 'value=NULL' if <VALUE> is empty.",
    "expressions": [
      "sub(\"^field:(?<val>.*)$\"; \"value=\\(.val | if length==0 then \\\"NULL\\\" else . end )\")",
      "sub(\"^(field:(?<val>.+)|field:)$\"; \"value=\\(.val // \\\"NULL\\\")\")"
    ],
    "data": [
      {
        "input": [
          "field:bla",
          "field:"
        ],
        "output": [
          "value=bla",
          "value=NULL"
        ]
      }
    ],
    "identifier": 73102684
  },
  {
    "context": [
      "I want to merge the objects and looking for some output like this",
      "The important ask here is the values are random and cannot be hardcoded.",
      "**Is there a way i can merge all the keys without hardcoding the key here?**",
      "Using `reduce`, then `unique` would be one way:",
      "jq '[\n  reduce (.[] | to_entries[]) as {$key, $value} ({}; .[$key] += [$value])\n  | map_values(unique)\n]'",
      "Using `group_by` and `map`, then `unique` again would be another:",
      "jq '[\n  map(to_entries[]) | group_by(.key)\n  | map({key: first.key, value: map(.value) | unique})\n  | from_entries\n]'"
    ],
    "utterance": "Merge all objects in an array, collecting each key's values into arrays, without specifying keys in advance.",
    "expressions": [
      "[\n  reduce (.[] | to_entries[]) as {$key, $value} ({}; .[$key] += [$value])\n  | map_values(unique)\n]",
      "[\n  map(to_entries[]) | group_by(.key)\n  | map({key: first.key, value: map(.value) | unique})\n  | from_entries\n]"
    ],
    "data": [
      {
        "input": [
          {
            "name": "hosts",
            "ipaddress": "1.2.3.4",
            "status": "UP",
            "randomkey": "randomvalue"
          },
          {
            "name": "hosts",
            "ipaddress": "5.6.7.8",
            "status": "DOWN",
            "newkey": "newvalue"
          },
          {
            "name": "hosts",
            "ipaddress": "9.10.11.12",
            "status": "RESTART",
            "anotherkey": "anothervalue"
          }
        ],
        "output": [
          {
            "name": [
              "hosts"
            ],
            "ipaddress": [
              "1.2.3.4",
              "5.6.7.8",
              "9.10.11.12"
            ],
            "status": [
              "UP",
              "DOWN",
              "RESTART"
            ],
            "randomkey": [
              "randomvalue"
            ],
            "newkey": [
              "newvalue"
            ],
            "anotherkey": [
              "anothervalue"
            ]
          }
        ]
      }
    ],
    "identifier": 73085216
  },
  {
    "context": [
      "This works perfectly fine but now I want to convert the json to string without escaping the double quotes of each key and value and just need to add single quotes at the end.",
      "# {\"key1\":\"value1\",\"key2\":\"value2\";} --->  '{\"key1\":\"value1\",\"key2\":\"value2\"}'",
      "Add `@json` to encode the result as JSON, then add `@sh` to escape the string for Shell compatibility, and replace the `-c` option to `-r` for raw output:",
      "jq -Rr 'split(\",\") | map( split(\":\") | {(.[0]): .[1]}) | add | @json | @sh' <<<\"$input\"",
      "'{\"key1\":\"value1\",\"key2\":\"value2\"}'"
    ],
    "utterance": "Convert an object to a string with unescaped double quotes around each key and value, and surround the entire result with single quotes.",
    "expressions": [
      "jq -Rr 'split(\",\") | map( split(\":\") | {(.[0]): .[1]}) | add | @json | @sh'"
    ],
    "data": [
      {
        "input": "key1:value1,key2:value2",
        "output": "'{\"key1\":\"value1\",\"key2\":\"value2\"}'"
      }
    ],
    "identifier": 73106165
  },
  {
    "context": [
      "Is there a way to produce output I need, but only for _result == 0_ (success) ?",
      "First, `select` only those with `.result == 0`, then navigate down to `.arguments.leases[]`, and eventually output your information:",
      "jq --raw-output '\n  .[0] | select(.result == 0) | .arguments.leases[]\n  | \"\\(.[\"hw-address\"]) \\(.[\"ip-address\"])\"\n'"
    ],
    "utterance": "Output only hw-address and ip-address values for leases, but only if result equals 0.",
    "expressions": [
      ".[0] | select(.result == 0) | .arguments.leases[] | \"\\(.\"hw-address\") \\(.\"ip-address\")\""
    ],
    "data": [
      {
        "input": [
          {
            "arguments": {
              "leases": [
                {
                  "cltt": 1658763299,
                  "fqdn-fwd": false,
                  "fqdn-rev": false,
                  "hostname": "",
                  "hw-address": "2c:ea:7f:ff:f6:36",
                  "ip-address": "192.168.1.2",
                  "state": 0,
                  "subnet-id": 1,
                  "valid-lft": 3600
                },
                {
                  "cltt": 1658763207,
                  "fqdn-fwd": false,
                  "fqdn-rev": false,
                  "hostname": "",
                  "hw-address": "2c:ea:7f:ff:f6:9c",
                  "ip-address": "192.168.1.3",
                  "state": 0,
                  "subnet-id": 1,
                  "valid-lft": 3600
                }
              ]
            },
            "result": 0,
            "text": "2 IPv4 lease(s) found."
          }
        ],
        "output": [
          "2c:ea:7f:ff:f6:36 192.168.1.2",
          "2c:ea:7f:ff:f6:9c 192.168.1.3"
        ]
      },
      {
        "input": [
          {
            "result": 1,
            "text": "unable to forward command to the dhcp4 service: No such file or directory. The server is likely to be offline"
          }
        ],
        "output": []
      }
    ],
    "identifier": 73115196
  },
  {
    "context": [
      "Can I somehow get the \"uid\" for the collection with \"name\" : \"Collecion Three\"",
      "Anything like SELECT uid FROM collections WHERE \"name\" = \"Collection Three\"",
      ".collections[] | select(.name == \"Collection Three\").uid"
    ],
    "utterance": "Retrieve the uid value for the collection whose name equals Collection Three.",
    "expressions": [
      ".collections[] | select(.name == \"Collection Three\").uid"
    ],
    "data": [
      {
        "input": {
          "collections": [
            {
              "id": "XXXXX-XXXX-XXXXX-XXXXX-XXXXXXX",
              "name": "Collection One",
              "owner": "me",
              "uid": "10020232-XXXXX-XXXX-XXXXX-XXXXX-XXXXXXX",
              "isPublic": false
            },
            {
              "id": "YYYYY-YYYY-YYYYY-YYYYY-YYYYYYY",
              "name": "Collection Two",
              "owner": "me",
              "uid": "10020232-YYYYY-YYYY-YYYYY-YYYYY-YYYYYYY",
              "isPublic": false
            },
            {
              "id": "ZZZZZ-ZZZZ-ZZZZZ-ZZZZZ-ZZZZZZZ",
              "name": "Collection Three",
              "owner": "me",
              "uid": "ZZZZZ-ZZZZ-ZZZZZ-ZZZZZ-ZZZZZZZ",
              "isPublic": false
            }
          ]
        },
        "output": "ZZZZZ-ZZZZ-ZZZZZ-ZZZZZ-ZZZZZZZ"
      }
    ],
    "identifier": 73124660
  },
  {
    "context": [
      "i need to convert it to csv with the following output format (pls, output example in picture attached).I'm only interested in picking out the dailysteps, weeklysteps and monthlysteps and adding a \"Total Steps\" column like in the picture attached",
      "It should have its custom Title Headers like this",
      "Daily Steps, Weekly Steps, Monthly Steps, Total Steps",
      "99 , 2377 , 330003 , 332479",
      "jq -r '\n  [\"Daily Steps\", \"Weekly Steps\", \"Monthly Steps\", \"Total Steps\"], \n  ([.dailysteps, .weeklysteps, .monthlysteps] | . + [add])\n  | @csv\n' data.json",
      "\"Daily Steps\",\"Weekly Steps\",\"Monthly Steps\",\"Total Steps\"\n99,2377,330003,332479"
    ],
    "utterance": "Output the values of dailysteps, weeklysteps, and monthlysteps, plus their sum as 'Total Steps', as a CSV file with custom headers.",
    "expressions": [
      "[\"Daily Steps\", \"Weekly Steps\", \"Monthly Steps\", \"Total Steps\"], ([.dailysteps, .weeklysteps, .monthlysteps] | . + [add]) | @csv"
    ],
    "data": [
      {
        "input": {
          "name": "john",
          "age": "22",
          "state": "Texas",
          "city": "Dallas",
          "dailysteps": 99,
          "weeklysteps": 2377,
          "monthlysteps": 330003
        },
        "output": "\"Daily Steps\",\"Weekly Steps\",\"Monthly Steps\",\"Total Steps\"\n99,2377,330003,332479"
      }
    ],
    "identifier": 73102270
  },
  {
    "context": [
      "I have a use case where I need to strip out the double colons to get the list of IP addresses.",
      "Input: (test.json)\n{\n  \"source_name\": \"ABC::10.0.0.1::XYZ ABC::10.0.0.2::XYZ ABC::10.0.0.3::XYZ\"\n}",
      "Desired output:\n10.0.0.1\n10.0.0.2\n10.0.0.3",
      "Split the string on spaces, then use substitution to remove the string before and after double colons:\n\n    jq -r '.source_name | split(\" \")[] | sub(\"^.*?::\"; \"\") | sub(\"::.*\"; \"\")' file.json",
      "Try this :\n\njq -r '.source_name | match(\"::(.*?)::\"; \"g\") | .captures[].string'",
      "Here's another approach using `scan`:\n\njq -r '.source_name | scan(\"::(.*?)::\")[]'"
    ],
    "utterance": "Extract each IP address that appears between double colons from the source_name field, outputting each IP on a separate line.",
    "expressions": [
      ".source_name | split(\" \")[] | sub(\"^.*?::\"; \"\") | sub(\"::.*\"; \"\")",
      ".source_name | match(\"::(.*?)::\"; \"g\") | .captures[].string",
      ".source_name | scan(\"::(.*?)::\")[]"
    ],
    "data": [
      {
        "input": {
          "source_name": "ABC::10.0.0.1::XYZ ABC::10.0.0.2::XYZ ABC::10.0.0.3::XYZ"
        },
        "output": [
          "10.0.0.1",
          "10.0.0.2",
          "10.0.0.3"
        ]
      }
    ],
    "identifier": 73124459
  },
  {
    "context": [
      "Now I&#39;d like to group and key that by &quot;folder/path&quot; and assign a list of id&#39;s to each of the path:",
      "jq &#39;.[].data.location.info | group_by(.folder.path) | \r\n    map({ path: (.[0].folder.path), id: [.[].key.id] })&#39; json",
      "def group(f):\r\n  group_by(f) | map({key:first|f, value:.}) | from_entries;\r\n  \r\n.[].data.location.info\r\n| group(.folder.path)\r\n| map_values(map(.key.id))"
    ],
    "utterance": "Group by folder.path and collect a list of key.id values for each unique path.",
    "expressions": [
      ".[].data.location.info | group_by(.folder.path) | map({ path: (.[0].folder.path), id: [.[].key.id] })",
      "def group(f): group_by(f) | map({key:first|f, value:.}) | from_entries; \n.[].data.location.info | group(.folder.path) | map_values(map(.key.id))"
    ],
    "data": [
      {
        "input": [
          {
            "data": {
              "location": {
                "info": [
                  {
                    "folder": {
                      "path": "/home/ip1"
                    },
                    "key": {
                      "id": "1234",
                      "label": "home"
                    }
                  },
                  {
                    "folder": {
                      "path": "/home/ip2"
                    },
                    "key": {
                      "id": "5678",
                      "label": "office"
                    }
                  },
                  {
                    "folder": {
                      "path": "/home/ip1"
                    },
                    "key": {
                      "id": "1001",
                      "label": "office"
                    }
                  },
                  {
                    "folder": {
                      "path": "/home/ip1"
                    },
                    "key": {
                      "id": "1002",
                      "label": "office"
                    }
                  }
                ]
              }
            }
          }
        ],
        "output": [
          {
            "path": "/home/ip1",
            "id": [
              "1234",
              "1001",
              "1002"
            ]
          },
          {
            "path": "/home/ip2",
            "id": [
              "5678"
            ]
          }
        ]
      }
    ],
    "identifier": 73124630
  },
  {
    "context": [
      "For every record in `.accounts[].vaults[].items[]`, I need to create/replace its `overview.tags` value with `[.Parent.Parent.attrs.name]`, if `.Parent` were to get the current element's parent in the tree.",
      "So the desired output would be this:\n\n```\n{\n  \"accounts\": [\n    {\n      \"attrs\": {\n        \"name\": \"One\"\n      },\n      \"vaults\": [\n        {\n          \"attrs\": {\"name\": \"Private\", \"type\": \"P\"},\n          \"items\": [\n            {\n              \"foo\": \"001\",\n              \"overview\": {\"subtitle\": \"foo\", \"tags\": [\"Private\"]}\n            },\n            {\n              \"foo\": \"002\",\n              \"overview\": {\"subtitle\": \"foo\", \"tags\": [\"Private\"]}\n            }\n          ]\n        },\n        {\n          \"attrs\": {\"name\": \"Public\", \"type\": \"P\"},\n          \"items\": [\n            {\n              \"foo\": \"001\",\n              \"overview\": {\"subtitle\": \"foo\", \"tags\": [\"Public\"]}\n            },\n            {\n              \"foo\": \"002\",\n              \"overview\": {\"subtitle\": \"foo\", \"tags\": [\"Public\"]}\n            }\n          ]\n        }\n      ]\n    }\n  ]\n}\n```",
      "One way to do it is using update-assignment `|=`\n```\njq '.accounts[].vaults |= map(.items[].overview.tags = [.attrs.name])'\n```"
    ],
    "utterance": "For every item, set the tags field inside overview to an array containing the parent vault's attrs.name value.",
    "expressions": [
      ".accounts[].vaults |= map(.items[].overview.tags = [.attrs.name])"
    ],
    "data": [
      {
        "input": {
          "accounts": [
            {
              "attrs": {
                "name": "One"
              },
              "vaults": [
                {
                  "attrs": {
                    "name": "Private",
                    "type": "P"
                  },
                  "items": [
                    {
                      "foo": "001",
                      "overview": {
                        "subtitle": "foo"
                      }
                    },
                    {
                      "foo": "002",
                      "overview": {
                        "subtitle": "foo",
                        "tags": [
                          "a tag"
                        ]
                      }
                    }
                  ]
                },
                {
                  "attrs": {
                    "name": "Public",
                    "type": "P"
                  },
                  "items": [
                    {
                      "foo": "001",
                      "overview": {
                        "subtitle": "foo"
                      }
                    },
                    {
                      "foo": "002",
                      "overview": {
                        "subtitle": "foo",
                        "tags": [
                          "a tag"
                        ]
                      }
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": {
          "accounts": [
            {
              "attrs": {
                "name": "One"
              },
              "vaults": [
                {
                  "attrs": {
                    "name": "Private",
                    "type": "P"
                  },
                  "items": [
                    {
                      "foo": "001",
                      "overview": {
                        "subtitle": "foo",
                        "tags": [
                          "Private"
                        ]
                      }
                    },
                    {
                      "foo": "002",
                      "overview": {
                        "subtitle": "foo",
                        "tags": [
                          "Private"
                        ]
                      }
                    }
                  ]
                },
                {
                  "attrs": {
                    "name": "Public",
                    "type": "P"
                  },
                  "items": [
                    {
                      "foo": "001",
                      "overview": {
                        "subtitle": "foo",
                        "tags": [
                          "Public"
                        ]
                      }
                    },
                    {
                      "foo": "002",
                      "overview": {
                        "subtitle": "foo",
                        "tags": [
                          "Public"
                        ]
                      }
                    }
                  ]
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 73030857
  },
  {
    "context": [
      "How to transform data about PCs from TeemIP IPAM database, to feed it to Kea DHCP server as reservations with jq.",
      "This is the data I would like to transform",
      "{\n  \"objects\": {\n    \"PC::8\": {\n      \"code\": 0,\n      \"message\": \"\",\n      \"class\": \"PC\",\n      \"key\": \"8\",\n      \"fields\": {\n        \"name\": \"ntb\",\n        \"macaddress\": \"50:74:9d:b5:5f:5d\",\n        \"ipaddress_id_friendlyname\": \"10.1.1.6\"\n      }\n    },\n    \"PC::7\": {\n      \"code\": 0,\n      \"message\": \"\",\n      \"class\": \"PC\",\n      \"key\": \"7\",\n      \"fields\": {\n        \"name\": \"pc\",\n        \"macaddress\": \"00:11:c0:92:ab:0e\",\n        \"ipaddress_id_friendlyname\": \"10.1.70.70\"\n      }\n    }\n  },\n  \"code\": 0,\n  \"message\": \"Found: 2\"\n}",
      "to this output",
      "{\n\"hostname\": \"ntb\",\n\"hw-address\": \"50:74:9d:b5:5f:5d\",\n\"ip-address\": \"10.1.1.6\"\n},\n{\n\"hostname\": \"pc\",\n\"hw-address\": \"00:11:c0:92:ab:0e\",\n\"ip-address\": \"10.1.70.70\"\n}",
      "Navigate to and iterate over the target items using `.objects[].fields`, and construct your objects:",
      "jq '\n  .objects[].fields | {\n    hostname: .name,\n    \"hw-address\": .macaddress,\n    \"ip-address\": .ipaddress_id_friendlyname\n  }\n'"
    ],
    "utterance": "Extract each PC's 'name', 'macaddress', and 'ipaddress_id_friendlyname' from the database, and output objects with keys 'hostname', 'hw-address', and 'ip-address' respectively for each PC.",
    "expressions": [
      ".objects[].fields | {hostname: .name, \"hw-address\": .macaddress, \"ip-address\": .ipaddress_id_friendlyname}"
    ],
    "data": [
      {
        "input": {
          "objects": {
            "PC::8": {
              "code": 0,
              "message": "",
              "class": "PC",
              "key": "8",
              "fields": {
                "name": "ntb",
                "macaddress": "50:74:9d:b5:5f:5d",
                "ipaddress_id_friendlyname": "10.1.1.6"
              }
            },
            "PC::7": {
              "code": 0,
              "message": "",
              "class": "PC",
              "key": "7",
              "fields": {
                "name": "pc",
                "macaddress": "00:11:c0:92:ab:0e",
                "ipaddress_id_friendlyname": "10.1.70.70"
              }
            }
          },
          "code": 0,
          "message": "Found: 2"
        },
        "output": [
          {
            "hostname": "ntb",
            "hw-address": "50:74:9d:b5:5f:5d",
            "ip-address": "10.1.1.6"
          },
          {
            "hostname": "pc",
            "hw-address": "00:11:c0:92:ab:0e",
            "ip-address": "10.1.70.70"
          }
        ]
      }
    ],
    "identifier": 73119654
  },
  {
    "context": [
      "\"jq --compact-output --null-input '$ARGS.positional' --args -- \\\"${folders[@]}\\\"'\"",
      "jsonString==[\"a\",\"b\",\"c\"]"
    ],
    "utterance": "Convert a Bash array of directory paths to a JSON array of strings, one element per path.",
    "expressions": [
      "jq --compact-output --null-input '$ARGS.positional' --args -- \"${folders[@]}\""
    ],
    "data": [
      {
        "input": [
          "a",
          "b",
          "c"
        ],
        "output": [
          "a",
          "b",
          "c"
        ]
      }
    ],
    "identifier": 73134494
  },
  {
    "context": [
      "I need to get the image version from the digest that has the other tag with \"name\": \"latest\".",
      "Use `select` in combination with `any`:\n~~~sh\ncurl ... | jq -r '\n  .[] | select(.tags | any(.name == \"latest\"))\n  | first(.tags[] | select(.name != \"latest\")).name\n'\n~~~",
      "1.0.1234567890.ab12cd3"
    ],
    "utterance": "Extract the tag value that is not 'latest' from the digest entry whose tags include one named 'latest'.",
    "expressions": [
      ".[] | select(.tags | any(.name == \"latest\")) | first(.tags[] | select(.name != \"latest\")).name"
    ],
    "data": [
      {
        "input": [
          {
            "digest": "sha256:.......",
            "tags": [
              {
                "artifact_id": 123456,
                "name": "latest"
              },
              {
                "artifact_id": 123456,
                "name": "1.0.1234567890.ab12cd3"
              }
            ]
          },
          {
            "digest": "sha256:.......",
            "tags": [
              {
                "artifact_id": 234567,
                "name": "1.0.1234567890.bc23de4"
              }
            ]
          },
          {
            "digest": "sha256:.......",
            "tags": [
              {
                "artifact_id": 345678,
                "name": "1.0.1234567890.cd34ef5"
              }
            ]
          }
        ],
        "output": "1.0.1234567890.ab12cd3"
      }
    ],
    "identifier": 73127409
  },
  {
    "context": [
      "If the fruit.json file has any extra fruit elements that are not in the bash array I have to output it.",
      "Here is a \"pure jq\" solution to Part 3 except that it uses `printf` to facilitate the importing of the bash array:",
      "printf '%s\\n' \"${FRUITS[@]}\" | \n  jq -nRr --argfile fruit <(json) '($fruit.fruit | map(ascii_upcase)) - [inputs] | .[]'"
    ],
    "utterance": "List all elements present in the 'fruit' array of the file that are not contained in the given shell array.",
    "expressions": [
      "($fruit.fruit | map(ascii_upcase)) - [inputs] | .[]"
    ],
    "data": [
      {
        "input": {
          "fruit": [
            "apple",
            "orange",
            "pomegranate",
            "apricot",
            "mango"
          ]
        },
        "output": [
          "pomegranate",
          "apricot",
          "mango"
        ]
      }
    ],
    "identifier": 73131291
  },
  {
    "context": [
      "Is there a simple way to extract a sub tree from JSON, keeping the path?",
      "this would miss the `repositories` node it self.",
      "How can I filter a composer.json to include only certain sub trees?",
      "To wrap that content inside another object under a field named again `repositories`, create that object with such field and add the content using `{repositories: .repositories}`.",
      "As this pattern is so common, there is a shorthand for it: `{repositories}`.",
      "jq '{repositories}' composer.json"
    ],
    "utterance": "Extract the repositories section as an object containing only the repositories field and its subtree.",
    "expressions": [
      "{repositories}"
    ],
    "identifier": 73137977
  },
  {
    "context": [
      "How to convert it into a CSV like this using jq ?",
      "You can use **`to_entries`** in order to be able to derive key-value pairs, then combine the pieces by using **`join`** such as",
      "jq -r '. | to_entries[] | [ .key, .value ] | join(\",\")'",
      "or use without individually paraphraising *key* and *value* such as",
      "jq -r '. | to_entries[] | [ .[] ] | join(\",\")'",
      "or if the quotes should be kept within the results, then use",
      "jq -r '. | to_entries[] | [ .[] ] | @csv'"
    ],
    "utterance": "Convert an object with arbitrary keys and plain values into lines where each line contains the key and value separated by a comma.",
    "expressions": [
      ". | to_entries[] | [ .key, .value ] | join(\",\")",
      ". | to_entries[] | [ .[] ] | join(\",\")",
      ". | to_entries[] | [ .[] ] | @csv"
    ],
    "data": [
      {
        "input": {
          "a": 68370432,
          "b": 50462720,
          "c": 53608448,
          "d": 245039104
        },
        "output": [
          "a,68370432",
          "b,50462720",
          "c,53608448",
          "d,245039104"
        ]
      }
    ],
    "identifier": 73134794
  },
  {
    "context": [
      "I a have a short TSV stream that outputs key/value pairs and I would like to create a JSON object out of it, with `jq`.",
      "But, is it possible to get this output with a **single** `jq` call?",
      "jq -Rn 'reduce (inputs/\"\t\") as [$k,$v] ({}; .[$k] = $v)'",
      "jq -Rn '[inputs/\"\t\" | {key: .[0], value: .[1]}] | from_entries'"
    ],
    "utterance": "Convert a TSV stream of key/value pairs to a single object, where each key maps to its value, in one command.",
    "expressions": [
      "jq -Rn 'reduce (inputs/\"\\t\") as [$k,$v] ({}; .[$k] = $v)'",
      "jq -Rn '[inputs/\"\\t\" | {key: .[0], value: .[1]}] | from_entries'"
    ],
    "data": [
      {
        "input": [
          "key1\tval1",
          "key2\tval2"
        ],
        "output": {
          "key1": "val1",
          "key2": "val2"
        }
      }
    ],
    "identifier": 73145782
  },
  {
    "context": [
      "I have a json file with this content and want to convert it to CSV like below:",
      "CSV File format:\n```\n17,Business Division,131,Accounting,Accounting\n16,Cancellation Reason,114,Forgot\n```",
      "As result, the second line of the CSV file did not print\nI think it's because of the .industry[] object that did not available in the second object in my Json",
      "How can I print the above json in the needed format?",
      ".fields[] | [ .id, .name, .values[].id, .values[].name, .values[].industry[]? ] | @csv",
      "jq --raw-output '.fields[] | [ .id, .name, .values[].id, .values[].name, .values[].industry[]? ] | @csv'"
    ],
    "utterance": "Produce CSV rows for each field, including id, name, each value's id and name, and all industries if present; if industries are missing, output shorter line.",
    "expressions": [
      ".fields[] | [ .id, .name, .values[].id, .values[].name, .values[].industry[]? ] | @csv"
    ],
    "data": [
      {
        "input": {
          "fields": [
            {
              "id": 17,
              "name": "Business Division",
              "values": [
                {
                  "id": 131,
                  "name": "Accounting",
                  "industry": [
                    "Accounting"
                  ]
                }
              ]
            },
            {
              "id": 16,
              "name": "Cancellation Reason",
              "values": [
                {
                  "id": 114,
                  "name": "Forgot"
                }
              ]
            }
          ]
        },
        "output": [
          "17,\"Business Division\",131,\"Accounting\",\"Accounting\"",
          "16,\"Cancellation Reason\",114,\"Forgot\""
        ]
      }
    ],
    "identifier": 73138934
  },
  {
    "context": [
      "When I run the github action for reading the value\n\n```yaml\n  - name: Add new ECDSA to Organization\n    run: |\n      cat new_ecdsa_config.json | jq '.''\n```\n\nI get the following error:\n\n```none\nparse error: Invalid string: control characters from U+0000 through U+001F must be escaped at line 26, column 53\nError: Process completed with exit code 4.\n```\n",
      "If you want the JSON representation of a multiline string, you'd have to escape the newline, e.g. along the lines of:\n```\n{\n  \"certificate\": \"value long string\\nmultiline\"\n}\n```"
    ],
    "utterance": "Read the full contents of the 'certificate' key, including newline characters represented by '\\n'.",
    "expressions": [
      ".certificate"
    ],
    "data": [
      {
        "input": {
          "certificate": "value long string\nmultiline"
        },
        "output": "value long string\nmultiline"
      }
    ],
    "identifier": 73145161
  },
  {
    "context": [
      "I have a test.json file and I want to print:",
      "prob1, 9",
      "prob2, 10",
      "prob3, 11",
      "cat test.json | jq --raw-output '[].abc'",
      "return 9,10,11 but I am not sure how to print keys as well.",
      "{\n   \"prob1\":{\n      \"abc\":9,\n      \"abcd\":2,\n      \"Foo\":3\n   },\n   \"prob2\":{\n      \"abc\":10,\n      \"abcd\":2,\n      \"Foo\":3\n   },\n   \"prob3\":{\n      \"abc\":11,\n      \"abcd\":2,\n      \"Foo\":3\n   }\n}",
      "jq -r 'to_entries[] | \"\\(.key): \\(.value.abc)\"'",
      "jq -r 'keys[] as $key | .[$key] | \"\\( $key ): \\( .abc )\"'"
    ],
    "utterance": "List each top-level object's key and its corresponding 'abc' value in the format 'key: value'.",
    "expressions": [
      "to_entries[] | \"\\(.key): \\(.value.abc)\"",
      "keys[] as $key | .[$key] | \"\\($key): \\(.abc)\""
    ],
    "data": [
      {
        "input": {
          "prob1": {
            "abc": 9,
            "abcd": 2,
            "Foo": 3
          },
          "prob2": {
            "abc": 10,
            "abcd": 2,
            "Foo": 3
          },
          "prob3": {
            "abc": 11,
            "abcd": 2,
            "Foo": 3
          }
        },
        "output": [
          "prob1: 9",
          "prob2: 10",
          "prob3: 11"
        ]
      }
    ],
    "identifier": 73147417
  },
  {
    "context": [
      "Given\r\n```\r\n[3,4]\r\n[5,2]\r\n```\r\n\r\nI&#39;d like to produce:\r\n\r\n```\r\n[5,2]\r\n[3,4]\r\n```\r\n",
      "I tried this but it fails:\r\n```\r\necho &#39;[3,4] [5,2]&#39; | jq &#39;sort_by(.[1])&#39;\r\n\r\njq: error (at &lt;stdin&gt;:1): Cannot index number with number\r\njq: error (at &lt;stdin&gt;:1): Cannot index number with number\r\n```",
      "Use `-n` with `inputs` to access the stream&#39;s items. `[\u200c...]` collects them into an outer array, `sort_by(...)` sorts by criteria, `...[]` decomposes the outer array again, and `-c` makes the output compact\r\n~~~sh\r\njq -nc &#39;[inputs] | sort_by(.[1])[]&#39;\r\n~~~\r\n~~~json\r\n[5,2]\r\n[3,4]\r\n~~~"
    ],
    "utterance": "Output each array from the input, sorted by the value at index 1 in descending order.",
    "expressions": [
      "[inputs] | sort_by(.[1]) | reverse[]"
    ],
    "data": [
      {
        "input": [
          [
            3,
            4
          ],
          [
            5,
            2
          ]
        ],
        "output": [
          [
            5,
            2
          ],
          [
            3,
            4
          ]
        ]
      }
    ],
    "identifier": 73148723
  },
  {
    "context": [
      "Require output as below",
      "{ \"names\": \"examplename1\", \"availabledates1\":[ \"value1\", \"value4\" ], \"availabledates2\":[ \"value2\", \"value5\" ], \"availabledates3\":[ \"value3\", \"value6\" ] }",
      "Issue 1: This JQ ignores the first row in inputs.",
      "Issue 2: If the input data set is very large this jq takes too much memory and eventually fails to execute as its doing multiple iterations which needs parallel threads.",
      "Need here more efficient jq which does not fail on large data set and also considers first row in inputs.",
      "Using `reduce`:",
      "jq -n '\n  (reduce inputs as $i ({}; .[$i.name] |= (\n    .names = $i.name\n    | .avaliableDates1 += [$i.Date1]\n    | .avaliableDates2 += [$i.Date2]\n    | .avaliableDates3 += [$i.Date3]\n  )))[]\n' "
    ],
    "utterance": "Group input objects by name and for each name, output the name along with arrays of Date1, Date2, and Date3 values from all matching objects.",
    "expressions": [
      "jq -n '  (reduce inputs as $i ({}; .[$i.name] |= (    .names = $i.name    | .avaliableDates1 += [$i.Date1]    | .avaliableDates2 += [$i.Date2]    | .avaliableDates3 += [$i.Date3]  )))[]'"
    ],
    "data": [
      {
        "input": [
          {
            "name": "examplename1",
            "Date1": "value1",
            "Date2": "value2",
            "Date3": "value3"
          },
          {
            "name": "examplename1",
            "Date1": "value4",
            "Date2": "value5",
            "Date3": "value6"
          },
          {
            "name": "examplename2",
            "Date1": "value7",
            "Date2": "value8",
            "Date3": "value9"
          },
          {
            "name": "examplename2",
            "Date1": "value10",
            "Date2": "value11",
            "Date3": "value12"
          }
        ],
        "output": [
          {
            "names": "examplename1",
            "avaliableDates1": [
              "value1",
              "value4"
            ],
            "avaliableDates2": [
              "value2",
              "value5"
            ],
            "avaliableDates3": [
              "value3",
              "value6"
            ]
          },
          {
            "names": "examplename2",
            "avaliableDates1": [
              "value7",
              "value10"
            ],
            "avaliableDates2": [
              "value8",
              "value11"
            ],
            "avaliableDates3": [
              "value9",
              "value12"
            ]
          }
        ]
      }
    ],
    "identifier": 73147991
  },
  {
    "context": [
      "Is there way to have a variable keeping its value from object to object *without waiting until the end of the stream*, outputting it immediately after JQ processed the next object from input?",
      "For example, to have average temperature for all temperature measurements so far?",
      "The trick is to use `foreach`, like so:",
      "< stream.json jq -nc --unbuffered '\nforeach inputs as $in ({};\n   if .n == null then {n: 1, total: $in.temp}\n   else .n += 1 | .total += $in.temp\n   end;\n   $in + {avg: (.total / .n )})\n'",
      "or more concisely:",
      "< stream.json jq -nc --unbuffered '\nforeach inputs as $in ({};\n   .n += 1 | .total += $in.temp;\n   $in + {avg: (.total / .n )})\n'"
    ],
    "utterance": "Output the running average of temperature values for each object in a stream, emitting a new object with the current average after each input.",
    "expressions": [
      "foreach inputs as $in ({}; if .n == null then {n: 1, total: $in.temp} else .n += 1 | .total += $in.temp end; $in + {avg: (.total / .n )})",
      "foreach inputs as $in ({}; .n += 1 | .total += $in.temp; $in + {avg: (.total / .n )})"
    ],
    "data": [
      {
        "input": [
          {
            "temp": 10
          },
          {
            "temp": 20
          },
          {
            "temp": 15
          },
          {
            "temp": 11
          }
        ],
        "output": [
          {
            "temp": 10,
            "avg": 10
          },
          {
            "temp": 20,
            "avg": 15
          },
          {
            "temp": 15,
            "avg": 15
          },
          {
            "temp": 11,
            "avg": 14
          }
        ]
      }
    ],
    "identifier": 73161178
  },
  {
    "context": [
      "Pls i need help rounding up multiple columns in this .csv output.",
      "So far, i&#39;ve been able to pipe my jq output into awk and round up just a single column but don&#39;t know how to round up this 6 columns.",
      "What i&#39;m trying to achieve",
      "\"Hour\",\"A\",\"B\",\"C\",\"D\",\"E\",\"F\"",
      "\"09\",\"6.01\",\"6.09\",\"8.97\",\"5.03\",\"5.96\",\"1.23\"",
      "Update `|=` the relevant columns / fields as follows: Divide by `10`, then `round`, and divide again by `100`.",
      ".stack[].overflow |= (. / 10 | round / 100)"
    ],
    "utterance": "Round up all six specified stack overflow values divided by 1000 to two decimal places for csv output.",
    "expressions": [
      "[\"Hour\", \"A\", \"B\", \"C\", \"D\", \"E\", \"F\"], ([.stack.\"123\".overflow/1000, .stack.\"234\".overflow/1000, .stack.\"356\".overflow/1000, .stack.\"244\".overflow/1000, .stack.\"789\".overflow/1000, .stack.\"545\".overflow/1000] | map(tostring | tonumber | . *= 100 | round / 100 | tostring) | [$H] + .) | @csv",
      ".stack[].overflow |= (. / 10 | round / 100)"
    ],
    "data": [
      {
        "input": {
          "XXXX": "XXX",
          "XXXXX": "XXXXXXX",
          "stack": {
            "123": {
              "overflow": 6014.4703
            },
            "234": {
              "overflow": 6090.3888
            },
            "356": {
              "overflow": 8973.8136
            },
            "244": {
              "overflow": 5034.4258
            },
            "789": {
              "overflow": 5957.6018
            },
            "545": {
              "overflow": 1225.7363
            }
          }
        },
        "output": {
          "XXXX": "XXX",
          "XXXXX": "XXXXXXX",
          "stack": {
            "123": {
              "overflow": 6.01
            },
            "234": {
              "overflow": 6.09
            },
            "356": {
              "overflow": 8.97
            },
            "244": {
              "overflow": 5.03
            },
            "789": {
              "overflow": 5.96
            },
            "545": {
              "overflow": 1.23
            }
          }
        }
      }
    ],
    "identifier": 73153702
  },
  {
    "context": [
      "I\u2019m hoping to convert every UTC TimeStamp in the json to Singapore time(SNST=GMT+08:00)",
      "Drop `map` as your document is an object, not an array. Then, to convert the timestamps to Unix epoch seconds, it suffices to apply `fromdateiso8601`:",
      "jq '.HttpCodeData.UsageData[].TimeStamp |= fromdateiso8601' <<< \"${api_result}\"",
      "Note: If you wanted to include also `.StartTime` and `.EndTime`, just list them along on the LHS:",
      "(.StartTime, .HttpCodeData.UsageData[].TimeStamp, .EndTime) |= fromdateiso8601"
    ],
    "utterance": "Convert every UTC timestamp field (including StartTime, EndTime, and all UsageData[].TimeStamp) to Unix epoch seconds.",
    "expressions": [
      ".HttpCodeData.UsageData[].TimeStamp |= fromdateiso8601",
      "(.StartTime, .HttpCodeData.UsageData[].TimeStamp, .EndTime) |= fromdateiso8601"
    ],
    "data": [
      {
        "input": {
          "DataInterval": 300,
          "EndTime": "2022-07-25T15:15:00Z",
          "HttpCodeData": {
            "UsageData": [
              {
                "TimeStamp": "2022-07-29T03:00:00Z",
                "Value": {
                  "CodeProportionData": [
                    {
                      "Code": "404",
                      "Count": 36,
                      "Proportion": 0.022
                    },
                    {
                      "Code": "502",
                      "Count": 3,
                      "Proportion": 0.002
                    }
                  ]
                }
              },
              {
                "TimeStamp": "2022-07-29T03:05:00Z",
                "Value": {
                  "CodeProportionData": [
                    {
                      "Code": "404",
                      "Count": 27,
                      "Proportion": 0.015
                    },
                    {
                      "Code": "502",
                      "Count": 5,
                      "Proportion": 0.002
                    }
                  ]
                }
              }
            ]
          },
          "StartTime": "2022-07-25T15:10:00Z"
        },
        "output": {
          "DataInterval": 300,
          "EndTime": "2022-07-25T15:15:00Z",
          "HttpCodeData": {
            "UsageData": [
              {
                "TimeStamp": 1659063600,
                "Value": {
                  "CodeProportionData": [
                    {
                      "Code": "404",
                      "Count": 36,
                      "Proportion": 0.022
                    },
                    {
                      "Code": "502",
                      "Count": 3,
                      "Proportion": 0.002
                    }
                  ]
                }
              },
              {
                "TimeStamp": 1659063900,
                "Value": {
                  "CodeProportionData": [
                    {
                      "Code": "404",
                      "Count": 27,
                      "Proportion": 0.015
                    },
                    {
                      "Code": "502",
                      "Count": 5,
                      "Proportion": 0.002
                    }
                  ]
                }
              }
            ]
          },
          "StartTime": "2022-07-25T15:10:00Z"
        }
      }
    ],
    "identifier": 73163377
  },
  {
    "context": [
      "Below is the output I am trying to get from a json file. Can someone please help to get the expected output with line of code?",
      "Note : JSON file can't be changed and I don't want to get the 2nd ip address in the output.",
      "jq --arg regex '[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}' -r '\n  .result[0].description | split(\"\\n\")[-1] | [scan($regex)][0]\n' file.json",
      ".result[0].description | capture(\"Address: *(?<address>[0-9.]*)\").address"
    ],
    "utterance": "Retrieve only the first IP address listed in the 'description' field under the first element of the 'result' array.",
    "expressions": [
      ".result[0].description | split(\"\\n\")[-1] | [scan(\"[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\\.[0-9]{1,3}\")][0]",
      ".result[0].description | capture(\"Address: *(?<address>[0-9.]*)\").address"
    ],
    "data": [
      {
        "input": {
          "result": [
            {
              "description": "Validate application after update for expected operation\nVM Name: fldcldswps7175 \nManaged Instance ID: i-01a2asda390b99 \nIP Address: 10.199.157.67,10.199.157.68",
              "status": true
            },
            {
              "name": "XML",
              "good": false
            }
          ]
        },
        "output": "10.199.157.67"
      }
    ],
    "identifier": 73175227
  },
  {
    "context": [
      "I'm trying to get data with certain value. ex when device value is 10, get serialID qwer1234.",
      "I have tried `jq-win64 -c \".devices[].serialID | select(.devices.device == 10)\"` and I get error",
      "`jq: error (at C:\\test.json:60): Cannot index string with string \"devices\"`",
      "The appropriate jq query is:\n```\n.devices[] | select(.device == 10).serialID\n```"
    ],
    "utterance": "Get the serialID where device equals 10.",
    "expressions": [
      ".devices[] | select(.device == 10).serialID"
    ],
    "data": [
      {
        "input": {
          "devices": [
            {
              "device": 10,
              "serialID": "qwer1234"
            },
            {
              "device": 20,
              "serialID": "q1w2e3r4"
            },
            {
              "device": 30,
              "serialID": "wasd1234"
            }
          ]
        },
        "output": "qwer1234"
      }
    ],
    "identifier": 73180386
  },
  {
    "context": [
      "How to get key `name` value from above mentioned json. There is no deeper nested subsection of keys where I need to search.",
      "jq: error (at input.json:100): Cannot index array with string \"name\"",
      "I solved issue with below",
      "jq -r '.[] | .name' input.json",
      "If you don't want to be bothered with having to figure out the path to the key of interest, and if you don't mind the possibility that there might be several occurrences of a particular key name, then the following one-liner may be worth considering:",
      ".. | objects | select(.name).name"
    ],
    "utterance": "Extract the value of the top-level key 'name' from each object in an array at the root.",
    "expressions": [
      ".[] | .name",
      "-r '.[] | .name'",
      ".. | objects | select(.name).name"
    ],
    "data": [
      {
        "input": [
          {
            "accessTier": "Hot",
            "allowBlobPublicAccess": false,
            "allowCrossTenantReplication": null,
            "enableNfsV3": false,
            "encryption": {
              "encryptionIdentity": null,
              "keySource": "Microsoft.Storage",
              "keyVaultProperties": null,
              "requireInfrastructureEncryption": null,
              "services": {
                "blob": {
                  "enabled": true,
                  "keyType": "Account",
                  "lastEnabledTime": "xxxxxx"
                },
                "file": {
                  "enabled": true,
                  "keyType": "Account",
                  "lastEnabledTime": "xxxxxx"
                },
                "queue": null,
                "table": null
              }
            },
            "extendedLocation": null,
            "failoverInProgress": null,
            "geoReplicationStats": null,
            "id": "/subscriptions/xxxx-xxxx-xxxxx-xxxx/resourceGroups/xxxxxxxxxxxxe/providers/Microsoft.Storage/storageAccounts/xxxxxxxxxxxx",
            "identity": {
              "principalId": null,
              "tenantId": null,
              "type": "None",
              "userAssignedIdentities": null
            },
            "immutableStorageWithVersioning": null,
            "isHnsEnabled": true,
            "isLocalUserEnabled": null,
            "isSftpEnabled": null,
            "keyCreationTime": {
              "key1": "xxxxxxx",
              "key2": "xxxxxxx"
            },
            "keyPolicy": null,
            "kind": "StorageV2",
            "largeFileSharesState": null,
            "lastGeoFailoverTime": null,
            "location": "xxxxxxxx",
            "minimumTlsVersion": "TLS1_0",
            "name": "storageaccountfortest",
            "networkRuleSet": {
              "bypass": "xxxxxxx",
              "defaultAction": "Allow",
              "ipRules": [],
              "resourceAccessRules": null,
              "virtualNetworkRules": []
            },
            "primaryLocation": "xxxxxxxxx",
            "privateEndpointConnections": [],
            "provisioningState": "Succeeded",
            "publicNetworkAccess": null,
            "resourceGroup": "xxxxxxxxx",
            "routingPreference": null,
            "sasPolicy": null,
            "secondaryEndpoints": null,
            "secondaryLocation": null,
            "sku": {
              "name": "Standard_LRS",
              "tier": "Standard"
            }
          }
        ],
        "output": [
          "storageaccountfortest"
        ]
      }
    ],
    "identifier": 73167969
  },
  {
    "context": [
      "How can I sort the list?",
      "I am trying to sort by .name:",
      "jq -r 'sort_by(.name) | .list[] | [ .name, .ipv4[0] ] | @tsv' file.json",
      "Cannot index array with string \"name\"",
      "Insert `sort_by(.name)` after traversing to `.list` but before iterating over its items with `[]`:",
      "jq -r '.list | sort_by(.name)[] | [.name, .ipv4[0]] | @tsv' file.json"
    ],
    "utterance": "Sort the list of objects by the value of the name field before outputting each name and the first ipv4 address as tab-separated values.",
    "expressions": [
      ".list | sort_by(.name)[] | [.name, .ipv4[0]] | @tsv"
    ],
    "data": [
      {
        "input": {
          "list": [
            {
              "ipv4": [
                "192.168.64.193"
              ],
              "name": "node2",
              "release": "20.04 LTS",
              "state": "Running"
            },
            {
              "ipv4": [
                "192.168.64.192"
              ],
              "name": "node1",
              "release": "20.04 LTS",
              "state": "Running"
            }
          ]
        },
        "output": "node1\t192.168.64.192\nnode2\t192.168.64.193"
      }
    ],
    "identifier": 73187253
  },
  {
    "context": [
      "I would like to duplicate elements n-times in the first array based on the values of the second array.",
      "As seen in the example below I would like to have the first element of the first array two times and the second element of the array three times.",
      "[[\"1/optimized/17853791_fpx.tif\", \"3/optimized/17853793_fpx.tif\"],[\"2\", \"3\"]]",
      "The desired output should look like:\n[\"1/optimized/17853791_fpx.tif\", \"1/optimized/17853791_fpx.tif\", \"3/optimized/17853793_fpx.tif\", \"3/optimized/17853793_fpx.tif\", \"3/optimized/17853793_fpx.tif\"]",
      "transpose | map(limit(last | tonumber; repeat(first)))",
      "def r($in;n): range(0;n)|$in;\n\n.[1] |= map(tonumber)\n| transpose\n| map(r(first;last))",
      "[. as [$x, $n] | range(0;$n|length) as $i | range(0;$n[$i]|tonumber)|$x[$i]]"
    ],
    "utterance": "Duplicate each element from the first array as many times as specified by the corresponding value in the second array.",
    "expressions": [
      "transpose | map(limit(last | tonumber; repeat(first)))",
      "def r($in;n): range(0;n)|$in;\n\n.[1] |= map(tonumber)\n| transpose\n| map(r(first;last))",
      "[. as [$x, $n] | range(0;$n|length) as $i | range(0;$n[$i]|tonumber)|$x[$i]]"
    ],
    "data": [
      {
        "input": [
          [
            "1/optimized/17853791_fpx.tif",
            "3/optimized/17853793_fpx.tif"
          ],
          [
            "2",
            "3"
          ]
        ],
        "output": [
          "1/optimized/17853791_fpx.tif",
          "1/optimized/17853791_fpx.tif",
          "3/optimized/17853793_fpx.tif",
          "3/optimized/17853793_fpx.tif",
          "3/optimized/17853793_fpx.tif"
        ]
      }
    ],
    "identifier": 73188913
  },
  {
    "context": [
      "Is it possible using the following tools `jq`, `yq`, `xq`, to convert from either `YAML` or `JSON` back to an `XML` format ?",
      "jq:\n\n```jq\n\"@\"     as $attr_prefix |\n\"#text\" as $content_key |\n...\nfix_tree | node_to_xml\n```",
      "It's invoked using \n\n```sh\njq -r 'above progam' file.json >file.xml\n```",
      "Here is a sample of my sample `JSON` file:\n\n```json\n{\n  \"security-settings\": {\n    \"@xmlns\": \"urn:activemq:core\",\n    \"security-setting\": {\n      \"@match\": \"#\",\n      \"permission\": [\n        {\n          \"@type\": \"createNonDurableQueue\",\n          \"@roles\": \"admins\"\n        },\n        ...\n      ]\n    }\n  }\n}\n```",
      "I took a two-step approach. I first convert the input to an unambiguous format, then converting this result to XML. These two steps could be merged. Here's is the result of the first conversion of the provided input:",
      "[Demo](https://jqplay.org/s/d2RVehE0QS6) on jqplay"
    ],
    "utterance": "Convert a nested object with attributes marked by keys starting with '@' and text content as '#text' into an XML-formatted string, preserving attribute mapping and element nesting.",
    "expressions": [
      "\"@\"     as $attr_prefix |\n\"#text\" as $content_key |\n\n# \"&gt;\" (only) needs to be escaped if preceded by \"]])\". We'll do it unconditionally.\n# Some whitespace also needs escaping, at least in attribute. Not done here.\n{ \"&\": \"&amp;\", \"<\": \"&lt;\", \">\": \"&gt;\"    } as $escapes      |\n{ \"&\": \"&amp;\", \"<\": \"&lt;\", \"\\\"\": \"&quot;\" } as $attr_escapes |\n\ndef text_to_xml:          split( \"\" ) | map( $escapes[.]      // . ) | join( \"\" );\ndef text_to_xml_attr_val: split( \"\" ) | map( $attr_escapes[.] // . ) | join( \"\" );\n\ndef node_to_xml:\n   if type == \"string\" then\n      text_to_xml\n   else\n      (\n         if .attrs then\n            .attrs |\n            to_entries |\n            map( \" \" + .key + \"=\\\"\" + ( .value | text_to_xml_attr_val ) + \"\\\"\" ) |\n            join( \"\" )\n         else\n            \"\"\n         end\n      ) as $attrs |\n\n      if .children and ( .children | length ) > 0 then\n         ( .children | map( node_to_xml ) | join( \"\" ) ) as $children |\n         \"<\" + .name + $attrs + \">\" + $children + \"</\" + .name + \">\"\n      else\n         \"<\" + .name + $attrs + \"/>\"\n      end\n   end\n;\n\ndef fix_tree( $name ):\n   type as $type |\n   if $type == \"array\" then\n      .[] | fix_tree( $name )\n   elif $type == \"object\" then\n      reduce to_entries[] as { key: $k, value: $v } (\n         { name: $name, attrs: {}, children: [] };\n\n         if $k[0:1] == $attr_prefix then\n            .attrs[ $k[1:] ] = $v\n         elif $k == $content_key then\n            .children += [ $v ]\n         else\n            .children += [ $v | fix_tree( $k ) ]\n         end\n      )\n   else\n      { name: $name, attrs: {}, children: [ . ] }\n   end\n;\n\ndef fix_tree: fix_tree( \"\" ) | .children[];\n\nfix_tree | node_to_xml"
    ],
    "data": [
      {
        "input": {
          "security-settings": {
            "@xmlns": "urn:activemq:core",
            "security-setting": {
              "@match": "#",
              "permission": [
                {
                  "@type": "createNonDurableQueue",
                  "@roles": "admins"
                },
                {
                  "@type": "deleteNonDurableQueue",
                  "@roles": "admins"
                },
                {
                  "@type": "createDurableQueue",
                  "@roles": "admins"
                },
                {
                  "@type": "deleteDurableQueue",
                  "@roles": "admins"
                },
                {
                  "@type": "createAddress",
                  "@roles": "admins"
                },
                {
                  "@type": "deleteAddress",
                  "@roles": "admins"
                },
                {
                  "@type": "consume",
                  "@roles": "admins"
                },
                {
                  "@type": "browse",
                  "@roles": "admins"
                },
                {
                  "@type": "send",
                  "@roles": "admins"
                },
                {
                  "@type": "manage",
                  "@roles": "admins"
                }
              ]
            }
          }
        },
        "output": "<?xml version=\"1.0\"?>\n<security-settings xmlns=\"urn:activemq:core\">\n  <security-setting match=\"#\">\n    <permission type=\"createNonDurableQueue\" roles=\"admins\" />\n    <permission type=\"deleteNonDurableQueue\" roles=\"admins\" />\n    <permission type=\"createDurableQueue\" roles=\"admins\" />\n    <permission type=\"deleteDurableQueue\" roles=\"admins\" />\n    <permission type=\"createAddress\" roles=\"admins\" />\n    <permission type=\"deleteAddress\" roles=\"admins\" />\n    <permission type=\"consume\" roles=\"admins\" />\n    <permission type=\"browse\" roles=\"admins\" />\n    <permission type=\"send\" roles=\"admins\" />\n    <permission type=\"manage\" roles=\"admins\" />\n  </security-setting>\n</security-settings>"
      }
    ],
    "identifier": 73038301
  },
  {
    "context": [
      "What I want to achieve is something like this:\r\n\r\n    {\r\n      \"foo\": {\r\n        \"bar\": {\r\n          \"baz\": 123\r\n        },\r\n        \"bislot\":\r\n          [[1,2,3,4,5],\r\n          [6,7,8,9,10],\r\n          [11,12,13,14,15]]\r\n      }\r\n    }\r\n\r\nSo for 2D arrays every item(array) should be in one line.",
      "`jq` by default pretty-prints its output. It also offers a `--compact-output` (or `-c`) option to output each JSON document into one line, which in your case would result in\n~~~sh\njq -c . file.json\n~~~",
      "An easy way could be to encode all arrays within arrays as JSON, thus becoming strings, which when pretty-printing the whole document with `jq` won't be broken down anymore:\n~~~sh\njq 'walk(arrays[] |= (arrays |= @json))' file.json\n~~~",
      "Going further, you could take the output from the previous call, read it line by line back into `jq`, decode lines with JSON-encoded arrays using `fromjson`, and output the modified lines (together masquerading as JSON document)."
    ],
    "utterance": "Format a 2D array so that each inner array appears on a single line in the pretty-printed output.",
    "expressions": [
      "jq -c .",
      "jq 'walk(arrays[] |= (arrays |= @json))' file.json"
    ],
    "data": [
      {
        "input": {
          "foo": {
            "bar": {
              "baz": 123
            },
            "bislot": [
              [
                1,
                2,
                3,
                4,
                5
              ],
              [
                6,
                7,
                8,
                9,
                10
              ],
              [
                11,
                12,
                13,
                14,
                15
              ]
            ]
          }
        },
        "output": "{\n  \"foo\": {\n    \"bar\": {\"baz\": 123},\n    \"bislot\": [[1,2,3,4,5], [6,7,8,9,10], [11,12,13,14,15]]\n  }\n}"
      }
    ],
    "identifier": 73190641
  },
  {
    "context": [
      "What would be the fastest way with the minimum latency to group the lines by \"name\" with the minimum order change, like following?",
      "In brief - use `GROUP_BY/2`, defined by:\n\ndef GROUP_BY(stream;f): reduce stream as $x ({}; .[$x|f] += [$x]);\n",
      "In your case, you'd use this as follows:\nGROUP_BY(inputs; .name)[][]\n",
      "\"minimum order change\" is accomplished because jq constructs objects incrementally, adding new keys after old ones.",
      "\"fastest way\" is accomplished because this solution does not involve the sorting of the input.",
      "\"minimum latency\" is accomplished because the input is not \"slurped\"."
    ],
    "utterance": "Group multiple records by the value of the name field, keeping the order of groups and items as close as possible to their original appearance.",
    "expressions": [
      "def GROUP_BY(stream; f): reduce stream as $x ({}; .[$x|f] += [$x]); GROUP_BY(inputs; .name)[][]"
    ],
    "identifier": 73191532
  },
  {
    "context": [
      "It looks like that:\r\n\r\n        {\r\n          \"test\": {\r\n            \"UserData\": \"test\",\r\n            \"password\": \"123\"\r\n          },\r\n          \"test2\": {\r\n            \"UserData\": \"test2\",\r\n            \"password\": \"123\"\r\n          },\r\n          \"test3\": {\r\n            \"UserData\": \"test3\",\r\n            \"password\": \"123\"\r\n          }\r\n       }",
      "And I need it to look like that:\r\n\r\n        {\r\n          \"test\": [{\r\n            \"UserData\": \"test\",\r\n            \"password\": \"123\"\r\n          }],\r\n          \"test2\": [{\r\n            \"UserData\": \"test2\",\r\n            \"password\": \"123\"\r\n          }],\r\n          \"test3\": [{\r\n            \"UserData\": \"test3\",\r\n            \"password\": \"123\"\r\n          }]\r\n        }",
      "Using `jq`: Select each field of the object with `.[]`, and update it `|=` to itself wrapped in an array `[.]`.\r\n~~~sh\r\njq '.[] |= [.]' file.json\r\n~~~",
      "~~~json\r\n{\r\n  \"test\": [\r\n    {\r\n      \"UserData\": \"test\",\r\n      \"password\": \"123\"\r\n    }\r\n  ],\r\n  \"test2\": [\r\n    {\r\n      \"UserData\": \"test2\",\r\n      \"password\": \"123\"\r\n    }\r\n  ],\r\n  \"test3\": [\r\n    {\r\n      \"UserData\": \"test3\",\r\n      \"password\": \"123\"\r\n    }\r\n  ]\r\n}\r\n~~~"
    ],
    "utterance": "Wrap each object value in the top-level object in a single-element array, preserving their keys.",
    "expressions": [
      ".[] |= [.]"
    ],
    "data": [
      {
        "input": {
          "test": {
            "UserData": "test",
            "password": "123"
          },
          "test2": {
            "UserData": "test2",
            "password": "123"
          },
          "test3": {
            "UserData": "test3",
            "password": "123"
          }
        },
        "output": {
          "test": [
            {
              "UserData": "test",
              "password": "123"
            }
          ],
          "test2": [
            {
              "UserData": "test2",
              "password": "123"
            }
          ],
          "test3": [
            {
              "UserData": "test3",
              "password": "123"
            }
          ]
        }
      }
    ],
    "identifier": 73192940
  },
  {
    "context": [
      "I would like to list all artifacts (`name` and `version`) which have at least one `GPL` licence. The result should be sorted alphabeticaly by `name`. The query to handle it is as follows:",
      "[.artifacts[] | select(.licenses[] | startswith(\"GPL-\"))] | unique_by(.id) | sort_by(.name) | .[] | \"\\(.name) \\(.version)\"",
      "I checked with single quotes & escaping double quotes with backslashes on Windows with PowerShell. It works:",
      "cat .\\test.json | jq -r '[.artifacts[] | select(.licenses[] | startswith(\\\"GPL-\\\"))] | unique_by(.id) | sort_by(.name) | .[] | \\\"\\(.name) \\(.version)\\\"'"
    ],
    "utterance": "List all artifact names and versions with at least one license starting with 'GPL-', sorted alphabetically by name.",
    "expressions": [
      "[.artifacts[] | select(.licenses[] | startswith(\"GPL-\"))] | unique_by(.id) | sort_by(.name) | .[] | \"\\(.name) \\(.version)\""
    ],
    "data": [
      {
        "input": {
          "artifacts": [
            {
              "id": "foo",
              "name": "Foo",
              "version": "1.0",
              "licenses": [
                "GPL-1",
                "GPL-2"
              ]
            },
            {
              "id": "bar",
              "name": "Bar",
              "version": "3.0",
              "licenses": [
                "GPL-3",
                "Apache 2.0"
              ]
            },
            {
              "id": "ignored",
              "name": "Ignored",
              "version": "3.0",
              "licenses": [
                "Apache 2.0"
              ]
            }
          ]
        },
        "output": [
          "Bar 3.0",
          "Foo 1.0"
        ]
      }
    ],
    "identifier": 73193321
  },
  {
    "context": [
      "how I can merge two json variables in bash to get the desired output mentioned below {without manually lopping over .data[] array} ?",
      "firstJsonoObj='{\"data\" :[{\"id\": \"123\"},{\"id\": \"124\"}]}'",
      "SecondJsonoObj='{ \"etag\" :\" 234324\"}'",
      "desired output\n{\n\"data\" :[{\"id\": \"123\", \"etag\" :\" 234324\"},{\"id\": \"124\", \"etag\" :\" 234324\"}]}\n",
      "jq --argjson x \"$SecondJsonoObj\" '.data[] += $x' <<< \"$firstJsonoObj\"",
      "jq --argjson a \"$firstJsonoObj\" --argjson b \"$SecondJsonoObj\" -n '$a | .data[] += $b'",
      "echo \"${firstJsonoObj} ${SecondJsonoObj}\" | jq '.data[] += input'"
    ],
    "utterance": "Add the field etag with value ' 234324' from one variable to every object in the data array of another variable, resulting in each data element containing both id and etag.",
    "expressions": [
      ".data[] += $SecondJsonoObj",
      ".data[] += $x",
      ".data[] += $b",
      ".data[] += input"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": "123"
            },
            {
              "id": "124"
            }
          ]
        },
        "output": {
          "data": [
            {
              "id": "123",
              "etag": " 234324"
            },
            {
              "id": "124",
              "etag": " 234324"
            }
          ]
        }
      }
    ],
    "identifier": 73202939
  },
  {
    "context": [
      "I would like in JQ to substitute the values in the first array with the names in the second array based on the key \"size\" while keeping the length of the first array unchanged.",
      "So the wanted result would look like this:\n\n    [{\"size\":6M},{\"size\":6.5M},{\"size\":7M},{\"size\":7.5M},{\"size\":8M},{\"size\":8.5M},{\"size\":9M},{\"size\":9.5M},{\"size\":10M},{\"size\":11M},{\"size\":6M},{\"size\":6.5M},{\"size\":7M},{\"size\":7.5M},{\"size\":8M},{\"size\":8.5M},{\"size\":9M},{\"size\":9.5M},{\"size\":10M},{\"size\":6M},{\"size\":6.5M},{\"size\":7M},{\"size\":7.5M},{\"size\":8M},{\"size\":8.5M},{\"size\":9M},{\"size\":9.5M},{\"size\":10M}]",
      "jq **filter** file:\n```\n. as $in |\nreduce $in[1][] as $i ({}; .[$i.size|tostring] = $i.name) | . as $d |\nreduce $in[0][] as $j ([]; . += [{ \"size\" : $d[$j.size|tostring] }])\n```",
      "Alternative **filter**:\n```\n. as $in |\nreduce $in[1][] as $i ({}; .[$i.size|tostring] = $i.name) | . as $d |\n$in[0] | map_values ( .size = $d[.size|tostring] )\n```"
    ],
    "utterance": "Replace each object's size value in the first array with the corresponding name from the second array based on matching size key, preserving the array's length.",
    "expressions": [
      ". as $in |\nreduce $in[1][] as $i ({}; .[$i.size|tostring] = $i.name) | . as $d |\nreduce $in[0][] as $j ([]; . += [{ \"size\" : $d[$j.size|tostring] }])",
      ". as $in |\nreduce $in[1][] as $i ({}; .[$i.size|tostring] = $i.name) | . as $d |\n$in[0] | map_values ( .size = $d[.size|tostring] )"
    ],
    "data": [
      {
        "input": [
          [
            {
              "size": 0
            },
            {
              "size": 1
            },
            {
              "size": 2
            },
            {
              "size": 3
            },
            {
              "size": 4
            },
            {
              "size": 5
            },
            {
              "size": 6
            },
            {
              "size": 7
            },
            {
              "size": 8
            },
            {
              "size": 9
            },
            {
              "size": 0
            },
            {
              "size": 1
            },
            {
              "size": 2
            },
            {
              "size": 3
            },
            {
              "size": 4
            },
            {
              "size": 5
            },
            {
              "size": 6
            },
            {
              "size": 7
            },
            {
              "size": 8
            },
            {
              "size": 0
            },
            {
              "size": 1
            },
            {
              "size": 2
            },
            {
              "size": 3
            },
            {
              "size": 4
            },
            {
              "size": 5
            },
            {
              "size": 6
            },
            {
              "size": 7
            },
            {
              "size": 8
            }
          ],
          [
            {
              "size": 0,
              "name": "6M"
            },
            {
              "size": 1,
              "name": "6.5M"
            },
            {
              "size": 2,
              "name": "7M"
            },
            {
              "size": 3,
              "name": "7.5M"
            },
            {
              "size": 4,
              "name": "8M"
            },
            {
              "size": 5,
              "name": "8.5M"
            },
            {
              "size": 6,
              "name": "9M"
            },
            {
              "size": 7,
              "name": "9.5M"
            },
            {
              "size": 8,
              "name": "10M"
            },
            {
              "size": 9,
              "name": "11M"
            }
          ]
        ],
        "output": [
          {
            "size": "6M"
          },
          {
            "size": "6.5M"
          },
          {
            "size": "7M"
          },
          {
            "size": "7.5M"
          },
          {
            "size": "8M"
          },
          {
            "size": "8.5M"
          },
          {
            "size": "9M"
          },
          {
            "size": "9.5M"
          },
          {
            "size": "10M"
          },
          {
            "size": "11M"
          },
          {
            "size": "6M"
          },
          {
            "size": "6.5M"
          },
          {
            "size": "7M"
          },
          {
            "size": "7.5M"
          },
          {
            "size": "8M"
          },
          {
            "size": "8.5M"
          },
          {
            "size": "9M"
          },
          {
            "size": "9.5M"
          },
          {
            "size": "10M"
          },
          {
            "size": "6M"
          },
          {
            "size": "6.5M"
          },
          {
            "size": "7M"
          },
          {
            "size": "7.5M"
          },
          {
            "size": "8M"
          },
          {
            "size": "8.5M"
          },
          {
            "size": "9M"
          },
          {
            "size": "9.5M"
          },
          {
            "size": "10M"
          }
        ]
      }
    ],
    "identifier": 73183693
  },
  {
    "context": [
      "There is however one user that constantly needs to be manually re-created as it should not get removed when clearing the user pool.",
      "I&#39;m trying to figure out how I can exclude that specific user from the delete.",
      "You can use the [`select` function](https://stedolan.github.io/jq/manual/v1.6/#select(boolean_expression)) of jq directly:",
      "jq -r '.Users[].Username | select(. != \"excluded username\")'"
    ],
    "utterance": "List all usernames from the user pool except for the one with the value 'excluded username'.",
    "expressions": [
      ".Users[].Username | select(. != \"excluded username\")"
    ],
    "data": [
      {
        "input": {
          "Users": [
            {
              "Username": "alice"
            },
            {
              "Username": "bob"
            },
            {
              "Username": "excluded username"
            }
          ]
        },
        "output": [
          "alice",
          "bob"
        ]
      }
    ],
    "identifier": 73223452
  },
  {
    "context": [
      "How can I replace the value in a jq before the output?",
      "\"#*\" to \"-\" or \"##\" to \"-\" and \"#\" to \"###\"",
      "If you really must do it with a single jq expression, then what user [jhnc](https://stackoverflow.com/users/10971581/jhnc) wrote in the [comments](https://stackoverflow.com/questions/73202129/jq-replace-substring-in-value#comment129283694_73202129):",
      "> `jq -r '.fields.description | gsub(\"\\n#[#*]\";\"\\n-\") | gsub(\"\\n# \",\"\\n### \")'`"
    ],
    "utterance": "Transform the multiline string in the 'description' field so that lines beginning with '#*' or '##' are replaced with '-', and lines beginning with a single '#' are replaced with '###'.",
    "expressions": [
      ".fields.description | gsub(\"\\n#[#*]\";\"\\n-\") | gsub(\"\\n# \",\"\\n### \")"
    ],
    "data": [
      {
        "input": {
          "expand": "renderedFields,names,schema,operations,editmeta,changelog,versionedRepresentations",
          "id": "240937",
          "self": "https://placeholder.atlassian.net/rest/api/latest/issue/240937",
          "key": "placeholder-355",
          "fields": {
            "description": "We need the following page layout changes made (for all user profiles unless specified in front of the item):\n\n# Display {{TestAccount__c}} field on the account object underneath the *Pricing Group* field\n# Display {{blng__LegalEntity__c}} field that sits on {{Order Product}} to be visible on *Order* as well as *Contract* objects _(position doesn\u2019t matter). Read only is fine as long as that works on SF reports if we need to bring this attribute in_\n# Display {{blng__LegalEntity__c}} field that sits on *Invoice Lines* to be visible on the *Invoice* object _(position doesn\u2019t matter). Read only is fine as long as that works on SF reports if we need to bring this attribute in_\n# Display \u2018*Notes*\u2019 section on the credit request page - copy the one that exists on the contract object e.g. (sample below)\n!image-20220714-021135.png|width=50%!\n# -Display- *-Agent-* -field on contract object to enable users to see if account has an agent or not- \u2192 already in production (not needed)\n# Change default options for *tasks* - the default subjects are:\n#* Call\n#* Send Letter\n#* Send Quote\n#* Other\n# Need to update to the following:\n#* Call\n#* Video Call\n#* Face to Face Meeting\n# Add in *Contact hierarchy* functionality in Salesforce\n## Anyone can update the \u2018Reports to\u2019 field\n## Show the following fields on the hierarchy page"
          }
        },
        "output": "We need the following page layout changes made (for all user profiles unless specified in front of the item):\n\n### Display {{TestAccount__c}} field on the account object underneath the *Pricing Group* field\n### Display {{blng__LegalEntity__c}} field that sits on {{Order Product}} to be visible on *Order* as well as *Contract* objects _(position doesn\u2019t matter). Read only is fine as long as that works on SF reports if we need to bring this attribute in_\n### Display {{blng__LegalEntity__c}} field that sits on *Invoice Lines* to be visible on the *Invoice* object _(position doesn\u2019t matter). Read only is fine as long as that works on SF reports if we need to bring this attribute in_\n### Display \u2018*Notes*\u2019 section on the credit request page - copy the one that exists on the contract object e.g. (sample below)\n!image-20220714-021135.png|width=50%!\n### -Display- *-Agent-* -field on contract object to enable users to see if account has an agent or not- \u2192 already in production (not needed)\n### Change default options for *tasks* - the default subjects are:\n- Call\n- Send Letter\n- Send Quote\n- Other\n### Need to update to the following:\n- Call\n- Video Call\n- Face to Face Meeting\n### Add in *Contact hierarchy* functionality in Salesforce\n- Anyone can update the \u2018Reports to\u2019 field\n- Show the following fields on the hierarchy page"
      }
    ],
    "identifier": 73202129
  },
  {
    "context": [
      "I need to select values that have lists with a special element in some attributes:",
      "In this example, the first element must be selected, because its `Action` contains `s3:GetObject`.",
      "If I try to use `select` here, it does not work, because in the second element, `Action` does not contain a list, and `contains` can't iterate over it.",
      "But how can I combine both checks in our `select` ?",
      "Put `select(type==\"array\")` after traversing to an element (here `.Statement[].Action `) but before trying to iterate over its items (`[]`):",
      ".Statement[].Action | select(type==\"array\")[] | contains(\"s3:GetObject\")",
      "Actually, there is a built-in [shortcut](https://github.com/stedolan/jq/blob/master/src/builtin.jq#L54) to `select(type==\"array\")` called `arrays`, so this is equivalent:",
      ".Statement[].Action | arrays[] | contains(\"s3:GetObject\")"
    ],
    "utterance": "Select entries where the Action attribute is a list containing s3:GetObject, even if Action can also be a scalar in other entries.",
    "expressions": [
      ".Statement[] | select(.Action | (type == \"array\") and (index(\"s3:GetObject\") != null))",
      ".Statement[] | select(.Action | arrays | index(\"s3:GetObject\"))"
    ],
    "data": [
      {
        "input": {
          "Statement": [
            {
              "Effect": "Allow",
              "Action": [
                "s3:GetObject",
                "s3:ListBucket"
              ],
              "Resource": [
                {
                  "Fn::Join": [
                    "",
                    [
                      "arn:aws:s3:::",
                      "bucket*"
                    ]
                  ]
                },
                {
                  "Fn::Join": [
                    "",
                    [
                      "arn:aws:s3:::",
                      "bucket*"
                    ]
                  ]
                }
              ]
            },
            {
              "Effect": "Allow",
              "Action": "cloudformation:*",
              "Resource": [
                {
                  "Fn::Join": [
                    "",
                    [
                      "arn:aws:cloudformation:",
                      {
                        "Ref": "AWS::Region"
                      },
                      ":",
                      {
                        "Ref": "AWS::AccountId"
                      },
                      ":stack/",
                      {
                        "Ref": "AWS::StackName"
                      },
                      "/*"
                    ]
                  ]
                }
              ]
            }
          ]
        },
        "output": {
          "Effect": "Allow",
          "Action": [
            "s3:GetObject",
            "s3:ListBucket"
          ],
          "Resource": [
            {
              "Fn::Join": [
                "",
                [
                  "arn:aws:s3:::",
                  "bucket*"
                ]
              ]
            },
            {
              "Fn::Join": [
                "",
                [
                  "arn:aws:s3:::",
                  "bucket*"
                ]
              ]
            }
          ]
        }
      }
    ],
    "identifier": 73208407
  },
  {
    "context": [
      "Is there any way that i can get with JQ the url by searching for the name, like this?",
      "`jq -r  '.servers | select(.name==\"abc\") | .url'`",
      ".servers | build.servers[] | select(.name == \"abc\").url"
    ],
    "utterance": "Retrieve the url value for the server whose name is \"abc\" from an object with keys like 'servers[0].name' and 'servers[0].url'.",
    "expressions": [
      ".servers | build.servers[] | select(.name == \"abc\").url"
    ],
    "data": [
      {
        "input": {
          "servers": {
            "servers[0].name": "abc",
            "servers[0].url": "www.abc.test.com",
            "servers[1].name": "xyz",
            "servers[1].url": "www.xyz.test.com"
          }
        },
        "output": "www.abc.test.com"
      }
    ],
    "identifier": 73223588
  },
  {
    "context": [
      "But the problem is that the grid positions need to be properly incremented (the Y's) so that when you reload the Grafana dashboards, the panels nested under row panels get set to their proper locations.",
      "I tried using reduce and foreach but i'm not super good with these constructs yet.",
      "Can you help? Thanks!",
      "With your _existing_ approach as such, you need to reference the `y` field in each `$item` processed and increment its value, rather than the predefined value of `$currentY`...",
      "which again could be written as\n\n[\n    1 as $currentY |\n    foreach .[] as $item (\n        [];\n        (. + [ $item | .gridPos.y += $currentY ]); \n        last\n    )\n]\n",
      "which again could be written with a simple `walk` expression\n\n1 as $currentY |\n  walk ( if type == \"object\" and has(\"gridPos\") then .gridPos.y +=  $currentY else . end )"
    ],
    "utterance": "Increment each object's gridPos.y by a constant starting value so all gridPos.y fields are offset by that value.",
    "expressions": [
      "[\n    1 as $currentY |\n    foreach .[] as $item (\n        [];\n        (. + [$item * {\"gridPos\": {\"y\": ($currentY + $item.gridPos.y )}}]); \n        last\n    )\n]",
      "[\n    1 as $currentY |\n    foreach .[] as $item (\n        [];\n        (. + [ $item | .gridPos.y += $currentY ]); \n        last\n    )\n]",
      "1 as $currentY |\n  walk ( if type == \"object\" and has(\"gridPos\") then .gridPos.y +=  $currentY else . end )"
    ],
    "data": [
      {
        "input": [
          {
            "gridPos": {
              "h": 1,
              "w": 24,
              "x": 0,
              "y": 22
            },
            "panels": []
          },
          {
            "gridPos": {
              "h": 1,
              "w": 24,
              "x": 0,
              "y": 43
            },
            "panels": []
          },
          {
            "gridPos": {
              "h": 1,
              "w": 24,
              "x": 0,
              "y": 17
            },
            "panels": []
          }
        ],
        "output": [
          {
            "gridPos": {
              "h": 1,
              "w": 24,
              "x": 0,
              "y": 23
            },
            "panels": []
          },
          {
            "gridPos": {
              "h": 1,
              "w": 24,
              "x": 0,
              "y": 44
            },
            "panels": []
          },
          {
            "gridPos": {
              "h": 1,
              "w": 24,
              "x": 0,
              "y": 18
            },
            "panels": []
          }
        ]
      }
    ],
    "identifier": 73223223
  },
  {
    "context": [
      "Now I would like to filter based on the filter `key==1`. So the result should be:",
      "[ { \"vd\": [ { \"key\": 1 } ] } ]",
      "Traverse to the array in question `.[].vd`, and update `|=` with a `map` based on a `select` using your criteria `.key == 1`:",
      "jq '.[].vd |= map(select(.key == 1))'"
    ],
    "utterance": "Filter each object's 'vd' array to keep only items where 'key' equals 1, preserving the original object structure.",
    "expressions": [
      ".[].vd |= map(select(.key == 1))"
    ],
    "data": [
      {
        "input": [
          {
            "vd": [
              {
                "key": 1
              },
              {
                "key": 2
              }
            ]
          }
        ],
        "output": [
          {
            "vd": [
              {
                "key": 1
              }
            ]
          }
        ]
      }
    ],
    "identifier": 73223747
  },
  {
    "context": [
      "How can I get from **ALL** the comments matching `user.login=foobar` the most recent one?",
      "map(select(.user.login == \"foobar\"))"
    ],
    "utterance": "Find the most recent comment whose user.login is foobar.",
    "expressions": [
      "map(select(.user.login == \"foobar\")) | sort_by(.created_at) | last"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "user": {
              "login": "octocat"
            },
            "created_at": "2011-04-14T16:00:49Z"
          },
          {
            "id": 2,
            "user": {
              "login": "foobar"
            },
            "created_at": "2012-05-15T16:00:49Z"
          },
          {
            "id": 3,
            "user": {
              "login": "foobar"
            },
            "created_at": "2014-01-01T16:00:49Z"
          }
        ],
        "output": {
          "id": 3,
          "user": {
            "login": "foobar"
          },
          "created_at": "2014-01-01T16:00:49Z"
        }
      }
    ],
    "identifier": 73228374
  },
  {
    "context": [
      "I only need to have a result of the jq-query above, if the difference between a \"started\" and \"downloaded\" (or \"download failed\" or \"download canceled\") is larger than 3 minutes. If there is none, the result shall be empty.",
      "So the target result should look like:\r\n\r\n{\r\n  \"1wFTAgs9DP5RSnCqKV1eLf6N9wtk4EAtmN5DpSxcs8EjT69tGE\": \"2\",\r\n  \"anotherSatelliteID\": \"1\"\r\n}\r\n\r\nWhereof the number indicates the count of \"time lags\" larger 3 minutes between two timestamps per satelliteID.",
      "jq -Rn '\r\n    reduce (\r\n        inputs / \"\\t\" |\r\n        try ( .[4] |= fromjson ) catch empty |\r\n        select(.[4].Action == \"GET_AUDIT\") |\r\n        [\r\n            ( .[0] | sub(\"\\\\.\\\\d+Z$\"; \"Z\") | strptime(\"%Y-%m-%dT%H:%M:%SZ\") | mktime ),\r\n            .[3],\r\n            .[4].\"Satellite ID\",\r\n            .[4].\"Piece ID\"\r\n        ]\r\n    ) as [ $time, $event, $satelliteID, $pieceID ] (\r\n        [{},{}];\r\n        if $event == \"download started\"\r\n        then\r\n            .[1][$pieceID] = $time\r\n        else\r\n            if (.[1] | has($pieceID) | not) or ($time - .[1][$pieceID]) / 60 > 3\r\n            then\r\n                .[0][$satelliteID] += 1\r\n            else\r\n                .\r\n            end\r\n        end\r\n    ) |\r\n    if .[0] != {} then .[0] else empty end\r\n' /mnt/WD1003/logs/sn1.log"
    ],
    "utterance": "Count, for each Satellite ID, how many times the duration between a 'download started' and its matching 'downloaded', 'download failed', or 'download canceled' event for the same Piece ID exceeds 3 minutes; output the count per Satellite ID, omitting cases with no such lag.",
    "expressions": [
      "jq -Rn '\n    reduce (\n        inputs / \"\\t\" |\n        try ( .[4] |= fromjson ) catch empty |\n        select(.[4].Action == \"GET_AUDIT\") |\n        [\n            ( .[0] | sub(\"\\\\.\\\\d+Z$\"; \"Z\") | strptime(\"%Y-%m-%dT%H:%M:%SZ\") | mktime ),\n            .[3],\n            .[4].\"Satellite ID\",\n            .[4].\"Piece ID\"\n        ]\n    ) as [ $time, $event, $satelliteID, $pieceID ] (\n        [{},{}];\n        if $event == \"download started\"\n        then\n            .[1][$pieceID] = $time\n        else\n            if (.[1] | has($pieceID) | not) or ($time - .[1][$pieceID]) / 60 > 3\n            then\n                .[0][$satelliteID] += 1\n            else\n                .\n            end\n        end\n    ) |\n    if .[0] != {} then .[0] else empty end\n' /mnt/WD1003/logs/sn1.log"
    ],
    "data": [
      {
        "input": [
          "2022-07-24T02:37:47.570Z\t-\t-\tdownload started\t{\"Piece ID\": \"CDTQRMUZ\", \"Satellite ID\": \"1wFTAgs9\", \"Action\": \"GET_AUDIT\"}",
          "2022-07-24T02:37:47.770Z\t-\t-\tdownload started\t{\"Piece ID\": \"CDTQRMUZ\", \"Satellite ID\": \"1wFTAgs9\", \"Action\": \"GET_AUDIT\"}",
          "2022-07-24T02:37:47.815Z\t-\t-\tdownloaded\t{\"Piece ID\": \"CDTQRMUZ\", \"Satellite ID\": \"1wFTAgs9\", \"Action\": \"GET_AUDIT\"}",
          "2022-07-24T02:37:48.107Z\t-\t-\tdownloaded\t{\"Piece ID\": \"CDTQRMUZ\", \"Satellite ID\": \"1wFTAgs9\", \"Action\": \"GET_AUDIT\"}",
          "2022-07-26T15:47:12.285Z\t-\t-\tdownload started\t{\"Piece ID\": \"CDTQRMUZ\", \"Satellite ID\": \"IADTQX62\", \"Action\": \"GET_AUDIT\"}",
          "2022-07-26T15:48:13.362Z\t-\t-\tdownload started\t{\"Piece ID\": \"GFATHGO2\", \"Satellite ID\": \"4EXtmN5f\", \"Action\": \"GET_AUDIT\"}",
          "2022-07-26T15:48:13.693Z\t-\t-\tdownloaded\t{\"Piece ID\": \"GFATHGO2\", \"Satellite ID\": \"4EXtmN5f\", \"Action\": \"GET_AUDIT\"}",
          "2022-07-26T15:51:23.789Z\t-\t-\tdownloaded\t{\"Piece ID\": \"CDTQRMUZ\", \"Satellite ID\": \"IADTQX62\", \"Action\": \"GET_AUDIT\"}",
          "2022-07-26T16:11:30.625Z\t-\t-\tdownloaded\t{\"Piece ID\": \"MREMD5SU\", \"Satellite ID\": \"2LYZZEPV\", \"Action\": \"GET_AUDIT\"}",
          "2023-01-01T00:00:00.000Z - - \"missing TABs\" {\"Action\":\"GET_AUDIT\"}",
          "2022-01-01T00:00:00.000Z\t-\t-\t\"broken JSON\"\t{",
          "2023-01-01T00:00:00.000Z\t-\t-\t\"not a JSON object\"\t\"string\"",
          "2023-01-01T00:00:00.000Z\t-\t-\t\"no 'Action' key\"\t{}"
        ],
        "output": {
          "IADTQX62": 1,
          "2LYZZEPV": 1
        }
      }
    ],
    "identifier": 73126522
  },
  {
    "context": [
      "I would like to extract the ImageId for these 4 instances.",
      "I'm able to get the ImageId for individual ip addresses using this command",
      "`cat instances.json | jq '.Reservations[] | .Instances[] | select(.PrivateIpAddress == \"10.100.39.41\") | .ImageId'`",
      "for i in `cat ipAddressList` ; do jq '.Reservations[] | .Instances[] | select(.PrivateIpAddress == \\$i) | .ImageId' instances.json ; done",
      "What you need is",
      "for i in `cat ipAddressList` ; do jq '.Reservations[] | .Instances[] | select(.PrivateIpAddress == \"$i\") | .ImageId' instances.json ; done",
      "Don\u2019t inject data into code, use the `--arg` and `--argjson` options provided by `jq` to do that safely:",
      "for i in `cat ipAddressList`\n  do jq --arg i \"$i\" '\n    .Reservations[] | .Instances[]\n    | select(.PrivateIpAddress == $i) | .ImageId\n  ' instances.json\ndone",
      "jq --rawfile ips ipAddressList '\n  .Reservations[].Instances[]\n  | select(IN(.PrivateIpAddress; ($ips / \"\\n\")[])).ImageId\n' instances.json"
    ],
    "utterance": "Extract the ImageId values for all EC2 instances whose PrivateIpAddress matches any of the IP addresses listed in a file called ipAddressList.",
    "expressions": [
      ".Reservations[] | .Instances[] | select(.PrivateIpAddress == \"$i\") | .ImageId",
      ".Reservations[] | .Instances[] | select(.PrivateIpAddress == $i) | .ImageId",
      ".Reservations[].Instances[] | select(IN(.PrivateIpAddress; ($ips / \"\\n\")[])).ImageId"
    ],
    "identifier": 73233671
  },
  {
    "context": [
      "then I want to get the iamge name with tag and ID",
      "So my question is, how can I get the output as\n\n```\npython:3.9 b673851840e8\nalpine:latest d7d3d98c851f\n```",
      "Using `jq`, collect the required fields into an array and use any of the string concatenation operators. You could also use `join(\"\\t\")` in place of `@tsv` to retain consistent usage of `join` method.",
      "jq -r '[([.Repository, .Tag] | join(\":\")), .ID] | @tsv'"
    ],
    "utterance": "Produce lines containing the repository and tag separated by a colon, followed by the ID, such as 'python:3.9 b673851840e8'.",
    "expressions": [
      "[([.Repository, .Tag] | join(\":\")), .ID] | @tsv"
    ],
    "data": [
      {
        "input": {
          "Containers": "N/A",
          "CreatedAt": "2022-07-27 11:12:07 +1000 AEST",
          "CreatedSince": "8 days ago",
          "Digest": "<none>",
          "ID": "b673851840e8",
          "Repository": "python",
          "SharedSize": "N/A",
          "Size": "915MB",
          "Tag": "3.9",
          "UniqueSize": "N/A",
          "VirtualSize": "914.7MB"
        },
        "output": "python:3.9\tb673851840e8"
      },
      {
        "input": {
          "Containers": "N/A",
          "CreatedAt": "2022-07-19 07:00:15 +1000 AEST",
          "CreatedSince": "2 weeks ago",
          "Digest": "<none>",
          "ID": "d7d3d98c851f",
          "Repository": "alpine",
          "SharedSize": "N/A",
          "Size": "5.53MB",
          "Tag": "latest",
          "UniqueSize": "N/A",
          "VirtualSize": "5.529MB"
        },
        "output": "alpine:latest\td7d3d98c851f"
      }
    ],
    "identifier": 73235207
  },
  {
    "context": [
      "jq --arg file $file '.suppressions += [{\"file\": $file, \"_justification\": \"app setting file\"}]' <<< \"$(cat credScanSuppressionsFile.json)\" > credScanSuppressionsFile.json",
      "for env in develop staging demo preprod prod\ndo\n    file='azure_portal_variables\\'$env-$webapp_name.json\n    echo $file\n    jq --arg file $file '.suppressions += [{\"file\": $file, \"_justification\": \"app setting file\"}]' <<< \"$(cat credScanSuppressionsFile.json)\" > credScanSuppressionsFile.json\ndone"
    ],
    "utterance": "Append an object containing the filename and justification to the suppressions array for each environment, ensuring the filename includes a single backslash before the environment name.",
    "expressions": [
      ".suppressions += [{\"file\": $file, \"_justification\": \"app setting file\"}]"
    ],
    "data": [
      {
        "input": {
          "tool": "Credential Scanner",
          "suppressions": []
        },
        "output": {
          "tool": "Credential Scanner",
          "suppressions": [
            {
              "file": "azure_portal_variables\\develop-customer-brasil-forms.json",
              "_justification": "app setting file"
            }
          ]
        }
      }
    ],
    "identifier": 73248565
  },
  {
    "context": [
      "what i have is:\n```\n{\n  \"testindex_123\": {\n    \"aliases\": {\n      \"testindex\": {}\n    }\n  },\n  \"testindex_122\": {\n    \"aliases\": {\n      \"testindex\": {}\n    }\n  }\n}\n```",
      "and i want to create a script/run jq on that so it would produce\n```\n{\n    \"actions\" : [\n\t{\n\t    \"add\" : {\n\t\t\"index\" : \"testindex_122\",\n\t\t\"alias\" : \"testindex\",\n\t\t\"is_write_index\": false\n\t    }\n\t},\n\t{\n\t    \"add\" : {\n\t\t\"index\" : \"testindex_123\",\n\t\t\"alias\" : \"testindex\",\n\t\t\"is_write_index\": true\n\t    }\n\t}\n    ]\n}\n```",
      "> is it possible for boolean to come from higher number? for instance i will always want to restore from date in the future. so in that case 123 > 122therefore 122== false 123 == true. Does that make any sense?",
      "Store the maximum of those values in a variable, and while iterating, compare the current one to it:\n~~~sh\ndef keynum: (.key / \"_\")[-1] | tonumber;\n\n{actions: (to_entries | (map(keynum) | max) as $max | map({add: {\n  index: .key,\n  alias: .value.aliases | keys[],\n  is_write_index: (keynum == $max)\n}}))}\n~~~"
    ],
    "utterance": "For each key, produce an actions array with add objects containing index, alias, and is_write_index set to true only for the entry with the highest numeric suffix.",
    "expressions": [
      "def keynum: (.key / \"_\")[-1] | tonumber;\n{actions: (to_entries | (map(keynum) | max) as $max | map({add: {\n  index: .key,\n  alias: .value.aliases | keys[],\n  is_write_index: (keynum == $max)\n}}))}"
    ],
    "data": [
      {
        "input": {
          "testindex_123": {
            "aliases": {
              "testindex": {}
            }
          },
          "testindex_122": {
            "aliases": {
              "testindex": {}
            }
          }
        },
        "output": {
          "actions": [
            {
              "add": {
                "index": "testindex_123",
                "alias": "testindex",
                "is_write_index": true
              }
            },
            {
              "add": {
                "index": "testindex_122",
                "alias": "testindex",
                "is_write_index": false
              }
            }
          ]
        }
      }
    ],
    "identifier": 73238718
  },
  {
    "context": [
      "I will want to merge my final json file such that the tweet_id becomes the reference and the replies and username becomes the keys to merge them. So the final json file will be like the one below:",
      "As for the second issue, you could employ `JOIN` on `B.json` and a custom index (eg. from the first issue) on `A.json`:",
      "jq --slurpfile A A.json --slurpfile B B.json -n '\n  JOIN(\n    $A | reduce group_by(.tweet_id)[] as $g (\n      {}; .[$g[0].tweet_id].reply += ($g | map(.tweets))\n    );\n    $B[]; .tweet_id | @text; add\n  )\n'"
    ],
    "utterance": "Combine two files on tweet_id so each record from the second file is annotated with all reply data from the first file where tweet_id matches.",
    "expressions": [
      "jq --slurpfile A A.json --slurpfile B B.json -n '\n  JOIN(\n    $A | reduce group_by(.tweet_id)[] as $g (\n      {}; .[$g[0].tweet_id].reply += ($g | map(.tweets))\n    );\n    $B[]; .tweet_id | @text; add\n  )\n'"
    ],
    "data": [
      {
        "input": {
          "A.json": [
            {
              "tweet_id": "1212024242595926028",
              "username": "THPDPIO",
              "created_at": "2019-12-31T14:54:32.000Z",
              "tweets": {
                "0": "Folks, it\u2019s simple!! You know what to do and what not to do...don\u2019t drink and drive and you don\u2019t have to worry about ANY consequences.  Btw...jail is just a small part of it...think about the possibility killing someone or killing yourself...again it\u2019s simple... \ud83d\ude00 #stayhome"
              }
            },
            {
              "tweet_id": "1212024242595926028",
              "username": "TheAliciaRanae",
              "created_at": "2019-12-31T15:11:51.000Z",
              "tweets": {
                "1": "@THPDPIO Stay home and drink and pass out and leave everyone else alone lol that\u2019s what I\u2019ll be doing lol HAPPY NEW YEAR!"
              }
            },
            {
              "tweet_id": "1212024242595926028",
              "username": "duane4343",
              "created_at": "2019-12-31T15:21:37.000Z",
              "tweets": {
                "1": "@THPDPIO Happy New Year"
              }
            },
            {
              "tweet_id": "1212024242595926028",
              "username": "HollyBr34731868",
              "created_at": "2019-12-31T15:24:25.000Z",
              "tweets": {
                "1": "@THPDPIO Hope everyone has a safe night."
              }
            },
            {
              "tweet_id": "1211503874395254785",
              "username": "UNDPoliceDept",
              "created_at": "2019-12-30T04:26:46.000Z",
              "tweets": {
                "0": "Typical North Dakotan.... #BestCopsAround #NoTravelAdvised #StayHome"
              }
            },
            {
              "tweet_id": "1211503874395254785",
              "username": "UNDPoliceDept",
              "created_at": "2019-12-30T04:27:40.000Z",
              "tweets": {
                "1": "@NDHighwayPatrol"
              }
            },
            {
              "tweet_id": "1211503874395254785",
              "username": "BorgenEthan",
              "created_at": "2019-12-30T05:28:48.000Z",
              "tweets": {
                "1": "@UNDPoliceDept Nah i definitely look like the first one"
              }
            }
          ],
          "B.json": [
            {
              "author_id": 80083199,
              "tweet_id": 1212150612026151000,
              "username": "CTVdavidspence",
              "author_followers": 19572,
              "author_tweets": 73406,
              "author_description": "Retired broadcast Meteorologist. 2017 RTDNA Lifetime Achievement Award. Best of Calgary 2018, 2019.  AHS Patient and Family Advisor (volunteer)",
              "author_location": "Calgary",
              "text": "The Trans Canada Highway near #Sicamous BC.  #stayhome   Image from @DriveBC.",
              "created_at": 1577834201000,
              "retweets": 12,
              "replies": 4,
              "likes": 27,
              "quote_count": 0
            },
            {
              "author_id": 848959032370921500,
              "tweet_id": 1212024242595926000,
              "username": "THPDPIO",
              "author_followers": 4626,
              "author_tweets": 2383,
              "author_description": "Police Sgt.",
              "author_location": "Terre Haute, IN",
              "text": "Folks, it\u2019s simple!! You know what to do and what not to do...don\u2019t drink  and drive and you don\u2019t have to worry about ANY consequences.  Btw...jail is just a  small part of it...think about the possibility killing someone or killing  yourself...again it\u2019s simple... \ud83d\ude00\n#stayhome",
              "created_at": 1577804072000,
              "retweets": 11,
              "replies": 9,
              "likes": 84,
              "quote_count": 1
            }
          ]
        },
        "output": [
          {
            "author_id": 80083199,
            "tweet_id": 1212150612026151000,
            "username": "CTVdavidspence",
            "author_followers": 19572,
            "author_tweets": 73406,
            "author_description": "Retired broadcast Meteorologist. 2017 RTDNA Lifetime Achievement Award. Best of Calgary 2018, 2019.  AHS Patient and Family Advisor (volunteer)",
            "author_location": "Calgary",
            "text": "The Trans Canada Highway near #Sicamous BC.  #stayhome   Image from @DriveBC.",
            "created_at": 1577834201000,
            "retweets": 12,
            "replies": 4,
            "likes": 27,
            "quote_count": 0
          },
          {
            "author_id": 848959032370921500,
            "tweet_id": 1212024242595926000,
            "username": "THPDPIO",
            "author_followers": 4626,
            "author_tweets": 2383,
            "author_description": "Police Sgt.",
            "author_location": "Terre Haute, IN",
            "text": "Folks, it\u2019s simple!! You know what to do and what not to do...don\u2019t drink  and drive and you don\u2019t have to worry about ANY consequences.  Btw...jail is just a  small part of it...think about the possibility killing someone or killing  yourself...again it\u2019s simple... \ud83d\ude00\n#stayhome",
            "created_at": 1577804072000,
            "retweets": 11,
            "replies": 9,
            "likes": 84,
            "quote_count": 1,
            "reply": [
              {
                "0": "Folks, it\u2019s simple!! You know what to do and what not to do...don\u2019t drink and drive and you don\u2019t have to worry about ANY consequences.  Btw...jail is just a small part of it...think about the possibility killing someone or killing yourself...again it\u2019s simple... \ud83d\ude00 #stayhome"
              },
              {
                "1": "@THPDPIO Stay home and drink and pass out and leave everyone else alone lol that\u2019s what I\u2019ll be doing lol HAPPY NEW YEAR!"
              },
              {
                "1": "@THPDPIO Happy New Year"
              },
              {
                "1": "@THPDPIO Hope everyone has a safe night."
              }
            ]
          }
        ]
      }
    ],
    "identifier": 73143200
  },
  {
    "context": [
      "I would like in JQ to substitute the values in the first array with the names in the second array based on the key \"size\" while keeping the length of the first array unchanged.",
      "Given the input\n~~~json\n[\n  [\n    {\"size\":0}, {\"size\":1}, {\"size\":2}, {\"size\":3}, {\"size\":4},\n    {\"size\":5}, {\"size\":6}, {\"size\":7}, {\"size\":8}, {\"size\":9},\n    {\"size\":0}, {\"size\":1}, {\"size\":2}, {\"size\":3}, {\"size\":4},\n    {\"size\":5}, {\"size\":6}, {\"size\":7}, {\"size\":8}, {\"size\":0},\n    {\"size\":1}, {\"size\":2}, {\"size\":3}, {\"size\":4}, {\"size\":5},\n    {\"size\":6}, {\"size\":7}, {\"size\":8}\n  ],\n  [\n    {\"size\":0,\"name\":\"6M\"}, {\"size\":1,\"name\":\"6.5M\"},\n    {\"size\":2,\"name\":\"7M\"}, {\"size\":3,\"name\":\"7.5M\"},\n    {\"size\":4,\"name\":\"8M\"}, {\"size\":5,\"name\":\"8.5M\"},\n    {\"size\":6,\"name\":\"9M\"}, {\"size\":7,\"name\":\"9.5M\"},\n    {\"size\":8,\"name\":\"10M\"}, {\"size\":9,\"name\":\"11M\"}\n  ]\n]\n~~~",
      "you can generate an `INDEX` over the second item, and use it for reference in a `map` on the first\n~~~sh\n(.[1] | INDEX(.size)) as $map | .[0] | map($map[.size | tostring])\n~~~",
      "to get\n~~~json\n[\n  {\"size\":0,\"name\":\"6M\"}, {\"size\":1,\"name\":\"6.5M\"},\n  {\"size\":2,\"name\":\"7M\"}, {\"size\":3,\"name\":\"7.5M\"},\n  {\"size\":4,\"name\":\"8M\"}, {\"size\":5,\"name\":\"8.5M\"},\n  {\"size\":6,\"name\":\"9M\"}, {\"size\":7,\"name\":\"9.5M\"},\n  {\"size\":8,\"name\":\"10M\"}, {\"size\":9,\"name\":\"11M\"},\n  {\"size\":0,\"name\":\"6M\"}, {\"size\":1,\"name\":\"6.5M\"},\n  {\"size\":2,\"name\":\"7M\"}, {\"size\":3,\"name\":\"7.5M\"},\n  {\"size\":4,\"name\":\"8M\"}, {\"size\":5,\"name\":\"8.5M\"},\n  {\"size\":6,\"name\":\"9M\"}, {\"size\":7,\"name\":\"9.5M\"},\n  {\"size\":8,\"name\":\"10M\"}, {\"size\":0,\"name\":\"6M\"},\n  {\"size\":1,\"name\":\"6.5M\"}, {\"size\":2,\"name\":\"7M\"},\n  {\"size\":3,\"name\":\"7.5M\"}, {\"size\":4,\"name\":\"8M\"},\n  {\"size\":5,\"name\":\"8.5M\"}, {\"size\":6,\"name\":\"9M\"},\n  {\"size\":7,\"name\":\"9.5M\"}, {\"size\":8,\"name\":\"10M\"}\n]\n~~~"
    ],
    "utterance": "For each object in the first array, replace the size value with the corresponding name from the second array, matched by the shared size value, preserving the order and length.",
    "expressions": [
      "(.[1] | INDEX(.size)) as $map | .[0] | map($map[.size | tostring])"
    ],
    "data": [
      {
        "input": [
          [
            {
              "size": 0
            },
            {
              "size": 1
            },
            {
              "size": 2
            },
            {
              "size": 3
            },
            {
              "size": 4
            },
            {
              "size": 5
            },
            {
              "size": 6
            },
            {
              "size": 7
            },
            {
              "size": 8
            },
            {
              "size": 9
            },
            {
              "size": 0
            },
            {
              "size": 1
            },
            {
              "size": 2
            },
            {
              "size": 3
            },
            {
              "size": 4
            },
            {
              "size": 5
            },
            {
              "size": 6
            },
            {
              "size": 7
            },
            {
              "size": 8
            },
            {
              "size": 0
            },
            {
              "size": 1
            },
            {
              "size": 2
            },
            {
              "size": 3
            },
            {
              "size": 4
            },
            {
              "size": 5
            },
            {
              "size": 6
            },
            {
              "size": 7
            },
            {
              "size": 8
            }
          ],
          [
            {
              "size": 0,
              "name": "6M"
            },
            {
              "size": 1,
              "name": "6.5M"
            },
            {
              "size": 2,
              "name": "7M"
            },
            {
              "size": 3,
              "name": "7.5M"
            },
            {
              "size": 4,
              "name": "8M"
            },
            {
              "size": 5,
              "name": "8.5M"
            },
            {
              "size": 6,
              "name": "9M"
            },
            {
              "size": 7,
              "name": "9.5M"
            },
            {
              "size": 8,
              "name": "10M"
            },
            {
              "size": 9,
              "name": "11M"
            }
          ]
        ],
        "output": [
          {
            "size": 0,
            "name": "6M"
          },
          {
            "size": 1,
            "name": "6.5M"
          },
          {
            "size": 2,
            "name": "7M"
          },
          {
            "size": 3,
            "name": "7.5M"
          },
          {
            "size": 4,
            "name": "8M"
          },
          {
            "size": 5,
            "name": "8.5M"
          },
          {
            "size": 6,
            "name": "9M"
          },
          {
            "size": 7,
            "name": "9.5M"
          },
          {
            "size": 8,
            "name": "10M"
          },
          {
            "size": 9,
            "name": "11M"
          },
          {
            "size": 0,
            "name": "6M"
          },
          {
            "size": 1,
            "name": "6.5M"
          },
          {
            "size": 2,
            "name": "7M"
          },
          {
            "size": 3,
            "name": "7.5M"
          },
          {
            "size": 4,
            "name": "8M"
          },
          {
            "size": 5,
            "name": "8.5M"
          },
          {
            "size": 6,
            "name": "9M"
          },
          {
            "size": 7,
            "name": "9.5M"
          },
          {
            "size": 8,
            "name": "10M"
          },
          {
            "size": 0,
            "name": "6M"
          },
          {
            "size": 1,
            "name": "6.5M"
          },
          {
            "size": 2,
            "name": "7M"
          },
          {
            "size": 3,
            "name": "7.5M"
          },
          {
            "size": 4,
            "name": "8M"
          },
          {
            "size": 5,
            "name": "8.5M"
          },
          {
            "size": 6,
            "name": "9M"
          },
          {
            "size": 7,
            "name": "9.5M"
          },
          {
            "size": 8,
            "name": "10M"
          }
        ]
      }
    ],
    "identifier": 73184995
  },
  {
    "context": [
      "I want to parse a JSON file and extract some values, while also discarding or skipping certain entries if they contain substrings from another list passed in as an argument.",
      "The exclusions are to be based on substrings, not exact matches.",
      "You could use `all/2` as follows:",
      "< input.json jq --slurpfile blacklist args.json '\n .entities\n | map(select(.name as $n\n       | all( $blacklist[]; . as $b | $n | index($b) | not) ))\n'",
      "or more concisely (but perhaps less obviously correct):",
      ".entities | map( select( all(.name; index( $blacklist[]) | not) ))"
    ],
    "utterance": "Filter and extract the list of entities whose 'name' field does not contain any substrings from a provided blacklist.",
    "expressions": [
      ".entities | map(select(.name as $n | all($blacklist[]; . as $b | $n | index($b) | not)))",
      ".entities | map( select( all(.name; index( $blacklist[]) | not) ))"
    ],
    "data": [
      {
        "input": {
          "entities": [
            {
              "id": 600,
              "name": "foo-001"
            },
            {
              "id": 601,
              "name": "foo-002"
            },
            {
              "id": 602,
              "name": "foobar-001"
            }
          ]
        },
        "output": [
          {
            "id": 600,
            "name": "foo-001"
          },
          {
            "id": 601,
            "name": "foo-002"
          }
        ]
      }
    ],
    "identifier": 73264374
  },
  {
    "context": [
      "Run the JQ expression using a variable but did not work.",
      "$ jq -r --arg TARGET \"${TARGET}\" '.$TARGET.gcp.project_id' sample.json",
      "jq: error: syntax error, unexpected ...",
      "You\u2019re using variables fine, the problem is that [object-identifier syntax][1] doesn\u2019t allow general expressions.",
      "you can use the more general [generic object index][2] filter for arbitrary keys including those that are calculated by some expression, such as .[$TARGET]:",
      "$ TARGET=dev",
      "$ jq -r --arg TARGET \"${TARGET}\" '.[$TARGET].gcp.project_id' sample.json",
      "forecast-dev-1234"
    ],
    "utterance": "Select the project_id of the object whose top-level key matches the value of the TARGET variable.",
    "expressions": [
      ".[$TARGET].gcp.project_id"
    ],
    "data": [
      {
        "input": {
          "dev": {
            "gcp": {
              "project_id": "forecast-dev-1234",
              "project_number": "123456789",
              "endpoint_id": "6837352639743655936"
            }
          }
        },
        "output": "forecast-dev-1234"
      }
    ],
    "identifier": 73271316
  },
  {
    "context": [
      "I need get the following keys when ipRanges contains \"10.32.0.2/32\", like that:\nownerId, groupId, groupName, ipProtocol, toPort\n\n\"2222\",\"sg-2222\",\"Route-SGP\",\"tcp\",\"22\"\n\"1111\",\"sg-1111\",\"sg1\",\"tcp\",\"4439\"\n\"1111\",\"sg-1111\",\"sg1\",\"tcp\",\"3389\"",
      "jq -r --arg ip \"10.32.0.2/32\" '\n  .ipPermissions[] as $p | select(IN($p.ipRanges[]; $ip))\n  | [.ownerId, .groupId, .groupName, $p.ipProtocol, $p.toPort]\n  | @csv\n'",
      "jq 'select(.ipPermissions[]?.ipRanges[] | index(\"10.32.0.2/32\"))' | jq 'del(.ipPermissionsEgress) | . as $i| \"\\(.ownerId),\\(.groupId),\\($i.ipPermissions[] | select(.ipRanges | index(\"10.32.0.2/32\")) | \"\\(.toPort),\\(.ipProtocol)\")\"'"
    ],
    "utterance": "Extract ownerId, groupId, groupName, ipProtocol, and toPort for each entry where any ipPermissions.ipRanges contains \"10.32.0.2/32\".",
    "expressions": [
      ".ipPermissions[] as $p | select(IN($p.ipRanges[]; \"10.32.0.2/32\")) | [.ownerId, .groupId, .groupName, $p.ipProtocol, $p.toPort]",
      ". as $i | $i.ipPermissions[] | select(.ipRanges | index(\"10.32.0.2/32\")) | [$i.ownerId, $i.groupId, $i.groupName, .ipProtocol, .toPort]"
    ],
    "data": [
      {
        "input": [
          {
            "description": "James-only access",
            "groupName": "Route-SGP",
            "ipPermissions": [
              {
                "ipProtocol": "tcp",
                "toPort": 22,
                "ipRanges": [
                  "10.32.0.1/32",
                  "10.32.0.2/32"
                ]
              }
            ],
            "ownerId": "2222",
            "groupId": "sg-2222",
            "vpcId": "vpc-2222"
          },
          {
            "groupName": "sg1",
            "ipPermissions": [
              {
                "ipProtocol": "tcp",
                "toPort": 4439,
                "ipRanges": [
                  "10.32.0.2/32"
                ]
              },
              {
                "ipProtocol": "tcp",
                "toPort": 3389,
                "ipRanges": [
                  "10.32.0.1/32",
                  "10.32.0.2/32"
                ]
              },
              {
                "ipProtocol": "icmp",
                "toPort": -1,
                "ipRanges": [
                  "10.32.0.0/30"
                ]
              }
            ],
            "ownerId": "1111",
            "groupId": "sg-1111",
            "vpcId": "vpc-1111"
          }
        ],
        "output": [
          [
            "2222",
            "sg-2222",
            "Route-SGP",
            "tcp",
            22
          ],
          [
            "1111",
            "sg-1111",
            "sg1",
            "tcp",
            4439
          ],
          [
            "1111",
            "sg-1111",
            "sg1",
            "tcp",
            3389
          ]
        ]
      }
    ],
    "identifier": 73239771
  },
  {
    "context": [
      "I have a JSON String in bash as follows.",
      "I need to process this json using jq as follows.",
      "But I am getting an error like ",
      "> parse error: Invalid numeric literal at line 1, column 111",
      "I understand that this error causing due to the quoted \\\" inside the json string. But I just want a solution to process it in a right way."
    ],
    "utterance": "Extract the 'prTitle' values, even when they contain escaped double quotes, from a shell variable containing a JSON array.",
    "expressions": [
      "echo \"$sample\" | jq -r '.[].prTitle'"
    ],
    "data": [
      {
        "input": [
          {
            "prTitle": "Revert some thing",
            "name": "Some name"
          },
          {
            "prTitle": "Revert \\\"Add logs for issue analysis\\\"",
            "name": "Some name"
          }
        ],
        "output": [
          "Revert some thing",
          "Revert \\\"Add logs for issue analysis\\\""
        ]
      }
    ],
    "identifier": 73274793
  },
  {
    "context": [
      "I want to parse the date in metadata, here 2022-07-27, replace it by today's date (e.g. 2022-08-05), and set the delta (here 9 days), and add that delta to all other date found in \"data_1h\" / \"time\"",
      "replace modelrun_utc modelrun_updatetime_utc by today's date only, keeping the time.",
      "\"metadata\": { \"modelrun_utc\": \"2022-08-05 00:00\", \"modelrun_updatetime_utc\": \"2022-08-05 07:27\" }, \"data_1h\": { \"time\": [ \"2022-08-05 00:00\", \"2022-08-05 01:00\", \"2022-08-12 11:00\", \"2022-08-12 12:00\", \"2022-08-12 13:00\", \"2022-08-12 14:00\" ] }",
      "jq '(\n  .metadata.modelrun_utc | strptime(\"%Y-%m-%d %H:%M\")\n  | (now - mktime) / (24 * 60 * 60)\n) as $diffdays | .data_1h.time[] |= (\n  strptime(\"%Y-%m-%d %H:%M\") | .[2] += $diffdays\n  | mktime | strftime(\"%Y-%m-%d %H:%M\")\n)'"
    ],
    "utterance": "Update dates in the metadata fields and all times in the data_1h.time array by the delta between the metadata's modelrun_utc date and today, so that all dates are advanced to match today's date while preserving the time of day.",
    "expressions": [
      "(\n  .metadata.modelrun_utc | strptime(\"%Y-%m-%d %H:%M\")\n  | (now - mktime) / (24 * 60 * 60)\n) as $diffdays | .data_1h.time[] |= (\n  strptime(\"%Y-%m-%d %H:%M\") | .[2] += $diffdays\n  | mktime | strftime(\"%Y-%m-%d %H:%M\")\n)"
    ],
    "data": [
      {
        "input": {
          "metadata": {
            "modelrun_utc": "2022-07-27 00:00",
            "modelrun_updatetime_utc": "2022-07-27 07:27"
          },
          "data_1h": {
            "time": [
              "2022-07-27 00:00",
              "2022-07-27 01:00",
              "2022-08-03 11:00",
              "2022-08-03 12:00",
              "2022-08-03 13:00",
              "2022-08-03 14:00"
            ]
          }
        },
        "output": {
          "metadata": {
            "modelrun_utc": "2022-08-05 00:00",
            "modelrun_updatetime_utc": "2022-08-05 07:27"
          },
          "data_1h": {
            "time": [
              "2022-08-05 00:00",
              "2022-08-05 01:00",
              "2022-08-12 11:00",
              "2022-08-12 12:00",
              "2022-08-12 13:00",
              "2022-08-12 14:00"
            ]
          }
        }
      }
    ],
    "identifier": 73249426
  },
  {
    "context": [
      "But if I try to pass a variable in place of the index:\n$ lookup=-1; jq -cr --arg l \"$lookup\" '.arr[]|select(.id==$l)|.desc' <<<${'{\"arr\":[{\"id\":-1,\"desc\":\"foo\"},{\"id\":100}]}' }\ndoesn't produce output this time.",
      "Use `--argjson` instead of `--arg`.",
      "`--arg l \"$lookup\"` makes `$l` a string. With `--argjson l \"$lookup\"` it is interpreted as JSON, a number in this case, just as was `-1` in `.id==-1`, your working example.",
      "Or do an additional operation to use the `tonumber` flag to `$l`, indicating that you want the operation on a numeric equivalent of the string value passed. i.e. `($l|tonumber)`"
    ],
    "utterance": "Select the desc field from objects in arr where the id matches a variable lookup value, supporting numbers.",
    "expressions": [
      ".arr[] | select(.id == $l) | .desc",
      ".arr[] | select(.id == ($l|tonumber)) | .desc"
    ],
    "data": [
      {
        "input": {
          "arr": [
            {
              "id": -1,
              "desc": "foo"
            },
            {
              "id": 100
            }
          ]
        },
        "output": "foo"
      }
    ],
    "identifier": 73275634
  },
  {
    "context": [
      "I am trying to delete a key whose value is duplicated elsewhere. That is I would like to delete all occurences(duplicates) after the first occurence.",
      "Essentially I want to remove this duplicate key:pair `\"endpoint\":\"10.247.0.3\"` and leave the enclosing parentheses `{}`",
      ".clouds[] |= ({endpoint} as $endpoint | .[] |= walk(\n  (objects | select(contains($endpoint))) |= del(.endpoint)\n))"
    ],
    "utterance": "Remove all keys named endpoint whose value matches one previously seen, except for the first occurrence, leaving empty objects if endpoint is the only key.",
    "expressions": [
      ".clouds[] |= ({endpoint} as $endpoint | .[] |= walk((objects | select(contains($endpoint))) |= del(.endpoint)))"
    ],
    "data": [
      {
        "input": {
          "clouds": {
            "finfolk-vmaas": {
              "auth-types": [
                "oauth1"
              ],
              "endpoint": "http://10.125.0.10:5240/MAAS/",
              "type": "maas"
            },
            "vsphere": {
              "auth-types": [
                "userpass"
              ],
              "endpoint": "10.247.0.3",
              "regions": {
                "QA": {
                  "endpoint": "10.247.0.3"
                }
              },
              "type": "vsphere"
            }
          }
        },
        "output": {
          "clouds": {
            "finfolk-vmaas": {
              "auth-types": [
                "oauth1"
              ],
              "endpoint": "http://10.125.0.10:5240/MAAS/",
              "type": "maas"
            },
            "vsphere": {
              "auth-types": [
                "userpass"
              ],
              "endpoint": "10.247.0.3",
              "regions": {
                "QA": {}
              },
              "type": "vsphere"
            }
          }
        }
      }
    ],
    "identifier": 73277108
  },
  {
    "context": [
      "I would like improve this format for example add text before values.",
      "Status: ERROR\nMetricKey: new_coverage\nComparator: LT\n\nStatus: ERROR\nMetricKey: new_duplicated_lines_density\nComparator: GT",
      "The `{Status:.status, MetricKey:.metricKey,Comparator:.comparator}` you&#39;ve used creates JSON objects. What you seem to be looking for is just string concatenation:",
      "    \"Status: \" + .status, \"MetricKey: \" + .metricKey, \"Comparator: \" + .comparator"
    ],
    "utterance": "For each item where status is ERROR, print status, metricKey, and comparator each prefixed with text (e.g., 'Status: ', 'MetricKey: ', 'Comparator: '), one per line.",
    "expressions": [
      ".projectStatus.conditions[] | select(.status==\"ERROR\") | \"Status: \" + .status, \"MetricKey: \" + .metricKey, \"Comparator: \" + .comparator"
    ],
    "data": [
      {
        "input": {
          "projectStatus": {
            "conditions": [
              {
                "status": "ERROR",
                "metricKey": "new_coverage",
                "comparator": "LT"
              },
              {
                "status": "ERROR",
                "metricKey": "new_duplicated_lines_density",
                "comparator": "GT"
              },
              {
                "status": "OK",
                "metricKey": "coverage",
                "comparator": "LT"
              }
            ]
          }
        },
        "output": "Status: ERROR\nMetricKey: new_coverage\nComparator: LT\nStatus: ERROR\nMetricKey: new_duplicated_lines_density\nComparator: GT"
      }
    ],
    "identifier": 73285567
  },
  {
    "context": [
      "I am not able to get jq `any(condition)` working with dynamic attributes:",
      "jq 'any(.name == \"$my_value\")'",
      "Above returns always false, I've assigned a value `dolle` into `my_value`.",
      "If however, I run the same code like so, it returns true (as it should):",
      "jq 'any(.name == \"dolle\")'",
      "Here the json array that I give to jq:",
      "[{ \"name\": \"dolle\" }, { \"name\": \"polle\" }]"
    ],
    "utterance": "Check if any object has the name equal to the shell variable my_value.",
    "expressions": [
      "jq --arg my_value \"$my_value\" 'any(.name == $my_value)'"
    ],
    "data": [
      {
        "input": [
          {
            "name": "dolle"
          },
          {
            "name": "polle"
          }
        ],
        "output": true
      }
    ],
    "identifier": 73288419
  },
  {
    "context": [
      "I\u2019m trying to deduplicate all objects inside the array ```results``` that share the same key ```id```, and merge their ```path``` arrays.",
      "You could `group_by` the `.id` field, then for each group take the `first` item and replace its `.path` field with a `map` on the `.path` fields of all group members:",
      "jq 'map(.results |= (group_by(.id) | map(first + {path: map(.path)})))'"
    ],
    "utterance": "Deduplicate objects within each 'results' array that have the same 'id' and merge their 'path' values into arrays.",
    "expressions": [
      "map(.results |= (group_by(.id) | map(first + {path: map(.path)})))"
    ],
    "data": [
      {
        "input": [
          {
            "type": "apple",
            "results": [
              {
                "id": "apple1",
                "name": "appleName1",
                "path": "/some/path/a"
              },
              {
                "id": "apple1",
                "name": "appleName1",
                "path": "/some/path/b"
              },
              {
                "id": "apple2",
                "name": "appleName2",
                "path": "/some/path/c"
              }
            ]
          },
          {
            "type": "orange",
            "results": [
              {
                "id": "orange1",
                "name": "orangeName1",
                "path": "/some/path/a"
              },
              {
                "id": "orange1",
                "name": "orangeName1",
                "path": "/some/path/b"
              },
              {
                "id": "orange2",
                "name": "orangeName2",
                "path": "/some/path/c"
              }
            ]
          }
        ],
        "output": [
          {
            "type": "apple",
            "results": [
              {
                "id": "apple1",
                "name": "appleName1",
                "path": [
                  "/some/path/a",
                  "/some/path/b"
                ]
              },
              {
                "id": "apple2",
                "name": "appleName2",
                "path": [
                  "/some/path/c"
                ]
              }
            ]
          },
          {
            "type": "orange",
            "results": [
              {
                "id": "orange1",
                "name": "orangeName1",
                "path": [
                  "/some/path/a",
                  "/some/path/b"
                ]
              },
              {
                "id": "orange2",
                "name": "orangeName2",
                "path": [
                  "/some/path/c"
                ]
              }
            ]
          }
        ]
      }
    ],
    "identifier": 73278413
  },
  {
    "context": [
      "I cannot figure out how to select the value from the list that is not \"latest\".",
      "I tried to use jq \u00b4 select(. != \"latest\"\u00b4) but this returns the entire array, and not just the \"SOME_SHA\" value",
      "To select the first such value, if any, you could write:\n\n    first(.[]|select(. != $value))"
    ],
    "utterance": "Find the first element in the array that is not equal to 'latest'.",
    "expressions": [
      "first(.[] | select(. != \"latest\"))"
    ],
    "data": [
      {
        "input": [
          "latest",
          "SOME_SHA"
        ],
        "output": "SOME_SHA"
      }
    ],
    "identifier": 73304593
  },
  {
    "context": [
      "I have the a single JSON object as below,\r\n\r\n    {\r\n        \"someOtherArray\": [ {} , {} ],\r\n        \"a\": [\r\n            {\r\n                \"item1\": \"item1_value\",\r\n                \"item2\": \"item2_value\"\r\n            },\r\n            {\r\n                \"item1\": \"item1_value\",\r\n                \"item2\": \"item2_value\"\r\n            },\r\n            {\r\n                ....\r\n            },\r\n            \r\n            100 million more object\r\n        ]\r\n    }",
      "I'm trying to make each element in the array as a separate JSON object as below,\r\n\r\n    { \"a\": { \"item1\": \"item1_value\", \"item2\": \"item2_value\" } }\r\n    { \"a\": { \"item1\": \"item1_value\", \"item2\": \"item2_value\" } }",
      "To create your final structure, re-create the resulting object with the output of fromstream, and use the --compact-output (or -c) option to have each object on its separate line:\r\n~~~sh\r\njq --stream -nc '{a: fromstream(2 | truncate_stream(inputs))}' file.json\r\n~~~",
      "You could just tweak the standard answer:\r\n```\r\njq --stream -nc '\r\n  {\"a\": fromstream(2|truncate_stream(inputs | select(.[0][0]==\"a\")) )}\r\n'\r\n```"
    ],
    "utterance": "For each object in the array under key 'a', output an object with the same key 'a' and the object as its value, producing one object per line.",
    "expressions": [
      "jq --stream -nc '{a: fromstream(2 | truncate_stream(inputs))}'",
      "jq --stream -nc '{\"a\": fromstream(2|truncate_stream(inputs | select(.[0][0]==\"a\")) )}'"
    ],
    "data": [
      {
        "input": {
          "someOtherArray": [
            {},
            {}
          ],
          "a": [
            {
              "item1": "foo",
              "item2": 1
            },
            {
              "item1": "bar",
              "item2": 2
            }
          ]
        },
        "output": [
          {
            "a": {
              "item1": "foo",
              "item2": 1
            }
          },
          {
            "a": {
              "item1": "bar",
              "item2": 2
            }
          }
        ]
      }
    ],
    "identifier": 73282525
  },
  {
    "context": [
      "But the output I want looks more like this:  \n\n[\n  {\n    \"name\": \"UsersConnection\",\n    \"fields\": [ \"nodes\", \"edges\", \"pageInfo\", \"totalCount\" ]\n  },\n  {\n    \"name\": \"UsersEdge\",\n    \"fields\": [ \"cursor\", \"node\" ]\n  }\n]",
      "Assuming `.data.__schema.types` is an array, and so is `.fields`, you could try `map` in both cases:\n~~~sh\n.data.__schema.types | map({name: .name, fields: (.fields | map(.name))})\n~~~",
      "I totally missed that I put the fields object inside brackets like this:\n\n```jq '.data.__schema.types[] | {name: .name, fields: [.fields[]?.name?]}'```"
    ],
    "utterance": "Group all objects by 'name', collecting each one's 'fields' as an array of field names for each group.",
    "expressions": [
      ".data.__schema.types | map({name: .name, fields: (.fields | map(.name))})",
      ".data.__schema.types[] | {name: .name, fields: [.fields[]?.name?]}"
    ],
    "data": [
      {
        "input": [
          {
            "name": "UsersConnection",
            "fields": [
              {
                "name": "nodes"
              },
              {
                "name": "edges"
              },
              {
                "name": "pageInfo"
              },
              {
                "name": "totalCount"
              }
            ]
          },
          {
            "name": "UsersEdge",
            "fields": [
              {
                "name": "cursor"
              },
              {
                "name": "node"
              }
            ]
          }
        ],
        "output": [
          {
            "name": "UsersConnection",
            "fields": [
              "nodes",
              "edges",
              "pageInfo",
              "totalCount"
            ]
          },
          {
            "name": "UsersEdge",
            "fields": [
              "cursor",
              "node"
            ]
          }
        ]
      }
    ],
    "identifier": 73296799
  },
  {
    "context": [
      "I want to extract test fields which their values equal to true.",
      "It iterates over the array `.[]`, `select`s those item objects whose `.test` field evaluates to `true` (implicit), and traverses further down to the `.name` field.",
      "jq -r '.[] | select(.test).name' ddd"
    ],
    "utterance": "Extract the name fields of all elements whose test field is true.",
    "expressions": [
      ".[] | select(.test).name"
    ],
    "data": [
      {
        "input": [
          {
            "name": "AA",
            "program_url": "https://www.google.com",
            "test": false
          },
          {
            "name": "BB",
            "program_url": "https://yahoo.com",
            "test": true
          }
        ],
        "output": "BB"
      }
    ],
    "identifier": 73334530
  },
  {
    "context": [
      "I want to loop over each bucket, call the aws s3 api to get the region for each bucket and append the {\"region\": \"region_name\"} for each object inside `Buckets` array and persist the changes to file.",
      "I want only the `region` key added to each element but keep all the contents of file same.",
      "Keep the context by adding parentheses to the LHS as in `(.[][0].response.Buckets[] | select(.Name==$bucket)).region=$region`.",
      "`jq -r --arg bucket \"$bucket\" --arg region \"$region\" '(.[][0].response.Buckets[] | select(.Name==$bucket)).region=$region' $REPORT/s3.json | sponge $REPORT/temp.json`",
      "jq --slurpfile buckets <( jq -r '.[][0].response.Buckets[].Name' $REPORT/s3.json | while IFS= read -r bucket; do aws s3api get-bucket-location --bucket $bucket | jq --arg bucket \"$bucket\" '{Name: $bucket, region: .LocationConstraint}'; done ) '.[][0].response.Buckets = $buckets' $REPORT/s3.json | sponge $REPORT/temp.json"
    ],
    "utterance": "Add a region field to each object in the Buckets array, preserving all other data, after determining the region value for each bucket.",
    "expressions": [
      "(.[][0].response.Buckets[] | select(.Name==$bucket)).region=$region",
      ".[][0].response.Buckets = $buckets"
    ],
    "identifier": 73321337
  },
  {
    "context": [
      "So basically i need to get an interval between 2 dates and i have found how to do that using mktime, then deducting the two numbers.",
      "But from my searching in the strptime c library, there doesnt seem to be a way to parse a date containing milliseconds, so im asking if there is any way around this, or if there is any way to parse a date containing milliseconds.",
      "Edit: if there is any way to round up or down the date, or just remove the milliseconds that would work too",
      "You could strip the fractional seconds with a substitution, and then go via `strptime` ([required because of non-UTC timezone][1]) to get a Unix timestamp:",
      "| jq '.ActiveFrom\n  | sub(\"\\\\.[[:digit:]]+\"; \"\")\n  | strptime(\"%Y-%m-%dT%H:%M:%S%z\")\n  | mktime'"
    ],
    "utterance": "Obtain the Unix timestamp from a date-time string that includes fractional seconds and a timezone offset, by removing the fractional seconds before parsing.",
    "expressions": [
      ".ActiveFrom | sub(\"\\.[[:digit:]]+\"; \"\") | strptime(\"%Y-%m-%dT%H:%M:%S%z\") | mktime"
    ],
    "data": [
      {
        "input": {
          "ActiveFrom": "2022-02-13T11:32:01.321345+04:00",
          "ActiveTo": "2022-02-13T11:33:13.031743+04:00"
        },
        "output": 1644751921
      }
    ],
    "identifier": 73361217
  },
  {
    "context": [
      "I want the output of the jq to be ",
      "host1  10.1.2.3",
      "host1  10.2.3.4",
      "host1  10.3.4.5",
      "host2  10.1.2.2",
      "host2  10.4.5.6",
      "host3  10.1.18.1",
      "Save the ips individually to a variable to reference it inside the array:",
      "jq -r 'to_entries[] | .value[].ip as $ip | [.key, $ip] | @tsv'",
      "Instead of `to_entries` you can also use `keys_unsorted` to get access to the keys:",
      "jq -r 'keys_unsorted[] as $key | .[$key][] | [$key, .ip] | @tsv'"
    ],
    "utterance": "Print each host name together with every 'ip' value on separate lines.",
    "expressions": [
      "to_entries[] | .value[].ip as $ip | [.key, $ip] | @tsv",
      "keys_unsorted[] as $key | .[$key][] | [$key, .ip] | @tsv"
    ],
    "data": [
      {
        "input": {
          "host1": [
            {
              "ip": "10.1.2.3"
            },
            {
              "ip": "10.2.3.4"
            },
            {
              "ip": "10.3.4.5"
            }
          ],
          "host2": [
            {
              "ip": "10.1.2.2"
            },
            {
              "ip": "10.4.5.6"
            }
          ],
          "host3": [
            {
              "ip": "10.1.18.1"
            }
          ]
        },
        "output": "host1\t10.1.2.3\nhost1\t10.2.3.4\nhost1\t10.3.4.5\nhost2\t10.1.2.2\nhost2\t10.4.5.6\nhost3\t10.1.18.1"
      }
    ],
    "identifier": 73337721
  },
  {
    "context": [
      "What I am looking for is a way to achieve the following (preferably using `jq`):",
      "1. Select a tags \"Value\"-value by its \"Key\"-value",
      "2. Check whether it is existent and if not add an empty entry",
      "3. Put the value in the exact same place every time (maintain a certain order)",
      "5. Convert the resulting array of values into CSV",
      "jq -r '[.Tags[] | select(.Key==\"Name\"),select(.Key==\"Email\"),select(.Key==\"Company\") | .Value // \"\"] | @csv'",
      "def get($key):\n  map(select(.Key == $key))\n | if length == 0 then null else .[0].Value end;\n\n .Tags | [get(\"Name\"), get(\"Email\"), get(\"Company\")] | @csv"
    ],
    "utterance": "Output a CSV line with values for the keys Name, Email, and Company from Tags, preserving the order and including empty values if a tag is missing.",
    "expressions": [
      "def get($key): map(select(.Key == $key)) | if length == 0 then null else .[0].Value end; .Tags | [get(\"Name\"), get(\"Email\"), get(\"Company\")] | @csv"
    ],
    "data": [
      {
        "input": {
          "Tags": [
            {
              "Key": "Name",
              "Value": "NameOfUser"
            },
            {
              "Key": "Email",
              "Value": "EmailOfUser"
            },
            {
              "Key": "Company",
              "Value": "CompanyOfUser"
            }
          ]
        },
        "output": "\"NameOfUser\",\"EmailOfUser\",\"CompanyOfUser\""
      }
    ],
    "identifier": 73365007
  },
  {
    "context": [
      "eventually, I would like to apply 2 filters on my file, and write back to the same filename.",
      "it is possible to combine filters?"
    ],
    "utterance": "Apply two filters in sequence to a file and write the output back to the same file.",
    "expressions": [
      "jq 'filter1 | filter2' input.json > output.json"
    ],
    "identifier": 73376509
  },
  {
    "context": [
      "When converting JSON to csv, I have managed to create a csv file containing the data but there is no headers being displayed in the csv file.",
      "I have managed to create a csv file that contains the headers but no data.",
      "jq: error (at <stdin>:39688): string (\"Waled.Abdu...) has no keys",
      "I'd go with something like:",
      "jq -r '[\"username\", \"address\", \"id\", \"title\"],\n   (.entities[]\n    | (try .addresses[].address // null) as $a\n    | [.username, $a, .id, .title] ) \n   | @csv'"
    ],
    "utterance": "Export an array with columns username, address, id, and title to CSV, including a header row and handling cases where addresses may be empty.",
    "expressions": [
      "[\"username\", \"address\", \"id\", \"title\"], (.entities[] | (try .addresses[].address // null) as $a | [.username, $a, .id, .title]) | @csv"
    ],
    "data": [
      {
        "input": {
          "entities": [
            {
              "id": "d130",
              "name": "Abdoulaye, Aminata",
              "division": {
                "id": "d130",
                "name": "",
                "selfUri": "/api/v2/authorization/"
              },
              "chat": {
                "jabberId": "62a0e0b060"
              },
              "email": "Aminata.Abdoulaye@",
              "primaryContactInfo": [
                {
                  "address": "Aminata.Abdoulaye@",
                  "mediaType": "EMAIL",
                  "type": "PRIMARY"
                }
              ],
              "addresses": [
                {
                  "address": "Aminata.Abdoulaye@",
                  "mediaType": "EMAIL",
                  "type": "WORK"
                }
              ],
              "title": "Agent",
              "username": "Aminata.Abdoulaye@"
            },
            {
              "id": "b143",
              "name": "Abdulkadir, Waled",
              "division": {
                "id": "b143",
                "name": "",
                "selfUri": "/api/v2/authorization/"
              },
              "chat": {
                "jabberId": "63e6e"
              },
              "department": "Canada Solutions",
              "email": "Waled.Abdulkadir@",
              "primaryContactInfo": [
                {
                  "address": "Waled.Abdulkadir@",
                  "mediaType": "EMAIL",
                  "type": "PRIMARY"
                }
              ],
              "addresses": [],
              "state": "active",
              "title": "Engineer",
              "username": "Waled.Abdulkadir@",
              "manager": {
                "id": "f3cc8f83-14c0",
                "selfUri": "/api/v2/users/14c0"
              },
              "version": 4,
              "acdAutoAnswer": false,
              "selfUri": "/api/v2/users/14c0"
            }
          ]
        },
        "output": "\"username\",\"address\",\"id\",\"title\"\n\"Aminata.Abdoulaye@\",\"Aminata.Abdoulaye@\",\"d130\",\"Agent\"\n\"Waled.Abdulkadir@\",,\"b143\",\"Engineer\""
      }
    ],
    "identifier": 73308530
  },
  {
    "context": [
      "I have the following json files:\r\n\r\nFile1:\r\n\r\n``` \r\n[\r\n    {\r\n      \"id\": 1,\r\n      \"name\": \"serviceName\",\r\n      \"owner\": {\r\n        \"id\": 1,\r\n        \"name\": \"Nicole\"\r\n      }\r\n    }\r\n]\r\n```",
      "and File2:\r\n```\r\n[\r\n    {\r\n      \"id\": 1,\r\n      \"name\": \"Nicole\",\r\n      \"email\": \"nicole@email.com\"\r\n    }\r\n]\r\n```",
      "I would like to have them merged like this:\r\n```\r\n[\r\n    {\r\n      \"id\": 1,\r\n      \"name\": \"serviceName\",\r\n      \"owner\": {\r\n        \"id\": 1,\r\n        \"name\": \"Nicole\",\r\n        \"email\": \"nicole@email.com\"\r\n      }\r\n    }\r\n]\r\n```",
      "jq --argfile new file2.json '\r\n  ($new | INDEX(.id)) as $dict | .[].owner |= (\r\n    if $dict[.id | @text] then . + $dict[.id | @text] else . end\r\n  )\r\n' file1.json",
      "jq '\r\n  JOIN(\r\n    INDEX(input[]; .id); .[]; .id | @text; .[0].owner += .[1] | .[0]\r\n  )\r\n' file1.json file2.json"
    ],
    "utterance": "Merge two arrays of objects by adding the email field from an object in the second array to the matching owner's object in the first array when the id matches.",
    "expressions": [
      "jq --argfile new file2.json '  ($new | INDEX(.id)) as $dict | .[].owner |= (    if $dict[.id | @text] then . + $dict[.id | @text] else . end  )' file1.json",
      "jq '  JOIN(    INDEX(input[]; .id); .[]; .id | @text; .[0].owner += .[1] | .[0]  )' file1.json file2.json"
    ],
    "data": [
      {
        "input": [
          [
            {
              "id": 1,
              "name": "serviceName",
              "owner": {
                "id": 1,
                "name": "Nicole"
              }
            }
          ],
          [
            {
              "id": 1,
              "name": "Nicole",
              "email": "nicole@email.com"
            }
          ]
        ],
        "output": [
          {
            "id": 1,
            "name": "serviceName",
            "owner": {
              "id": 1,
              "name": "Nicole",
              "email": "nicole@email.com"
            }
          }
        ]
      }
    ],
    "identifier": 73355370
  },
  {
    "context": [
      "But now I want previous releases too so I want the index of a particular tag name. For eg: tag_name = \"10.3.1\"",
      "Just index of \"checkstyle-10.3.1\":",
      "curl -s https://api.github.com/repos/checkstyle/checkstyle/releases | jq '[.[].tag_name] | to_entries | .[] | select(.value==\"checkstyle-10.3.1\") | .key'",
      "Here's a general-purpose function to get the index of something in an array:",
      "def index_by(f): first(foreach .[] as $x (-1; .+1; if ($x|f) then . else empty end)) // null;",
      "jq '\n  def index_by(f): first(foreach .[] as $x (-1; .+1; if ($x|f) then . else empty end)) // null;\n\n  index_by(.tag_name == \"checkstyle-10.3.1\") as $i\n  | if $i then .[$i - 1] else empty end\n'"
    ],
    "utterance": "Find the index of the array element whose tag_name equals \"checkstyle-10.3.1\".",
    "expressions": [
      "[.[].tag_name] | to_entries | .[] | select(.value==\"checkstyle-10.3.1\") | .key",
      "def index_by(f): first(foreach .[] as $x (-1; .+1; if ($x|f) then . else empty end)) // null; index_by(.tag_name == \"checkstyle-10.3.1\")"
    ],
    "identifier": 73371445
  },
  {
    "context": [
      "I am trying to return JSON objects from this dataset that contain a key whose value matches \"builtin\" string using JQ.",
      "I wanted it to also include the top level containing object parentheses as well as the top level key like so:",
      "You can use the with_entries function that converts your objects into key and a value pair, which can in-turn be used for a select operation based on the condition\n\nwith_entries(select(.value.defined == \"built-in\"))",
      "jq '.[] |= select(.defined == \"built-in\")' clouds.json",
      "Note: For more readability, the `.[] |=` pattern is implemented by a function called `map_values`, so `jq 'map_values(select(.defined == \"built-in\"))' clouds.json` will have the same effect."
    ],
    "utterance": "Return an object containing only top-level keys whose inner object has a defined field equal to \"built-in\".",
    "expressions": [
      "with_entries(select(.value.defined == \"built-in\"))",
      ".[] |= select(.defined == \"built-in\")",
      "map_values(select(.defined == \"built-in\"))"
    ],
    "data": [
      {
        "input": {
          "aws": {
            "defined": "public",
            "type": "ec2",
            "description": "Amazon Web Services",
            "auth-types": [
              "access-key"
            ],
            "credential-count": 2,
            "regions": {
              "us-east-1": {
                "endpoint": "https://ec2.us-east-1.amazonaws.com"
              }
            }
          },
          "google": {
            "defined": "public",
            "type": "gce",
            "description": "Google Cloud Platform",
            "auth-types": [
              "jsonfile",
              "oauth2"
            ],
            "credential-count": 1,
            "regions": {
              "us-east1": {
                "endpoint": "https://www.googleapis.com"
              }
            }
          },
          "localhost": {
            "defined": "built-in",
            "type": "lxd",
            "description": "LXD Container Hypervisor",
            "auth-types": [
              "certificate"
            ],
            "credential-count": 1,
            "regions": {
              "localhost": {}
            }
          },
          "microk8s": {
            "defined": "built-in",
            "type": "k8s",
            "description": "A Kubernetes Cluster",
            "auth-types": [
              "certificate",
              "clientcertificate",
              "oauth2",
              "oauth2withcert",
              "userpass"
            ],
            "endpoint": "https://192.168.101.2:15443",
            "credential-count": 1,
            "regions": {
              "localhost": {}
            }
          }
        },
        "output": {
          "localhost": {
            "defined": "built-in",
            "type": "lxd",
            "description": "LXD Container Hypervisor",
            "auth-types": [
              "certificate"
            ],
            "credential-count": 1,
            "regions": {
              "localhost": {}
            }
          },
          "microk8s": {
            "defined": "built-in",
            "type": "k8s",
            "description": "A Kubernetes Cluster",
            "auth-types": [
              "certificate",
              "clientcertificate",
              "oauth2",
              "oauth2withcert",
              "userpass"
            ],
            "endpoint": "https://192.168.101.2:15443",
            "credential-count": 1,
            "regions": {
              "localhost": {}
            }
          }
        }
      }
    ],
    "identifier": 73274635
  },
  {
    "context": [
      "I would like to make (using jq) from input:",
      "{ key1: value1, key2: value2, key3: [ {key4: value3, key5: value5}, {key4: value4, key5: value6}, ..., {key4: valueN, key5: valueM}, ... ] }",
      "this output:",
      "{ key1: value1, key2: value2, value3: value5, value4: value6, ..., valueN: valueM, ... }",
      "For the given input, the following should produce the desired output",
      ".key3 as $t | del(.key3) | . + ( $t | map(to_entries | { (.[0].value) : .[1].value } ) | add )",
      "reduce .key3[] as {$key4, $key5} (del(.key3); .[$key4] = $key5)",
      "Pipe to `from_entries`: ( ... | from_entries) as $obj | . + $obj | del(.key3)"
    ],
    "utterance": "Transform an object containing an array of objects (each with keys key4 and key5) into a single object where each key4 value becomes a key with key5 value as its value, merged with the original object's other keys.",
    "expressions": [
      ".key3 as $t | del(.key3) | . + ( $t | map({ (.key4): .key5 }) | add )",
      "reduce .key3[] as {$key4, $key5} (del(.key3); .[$key4] = $key5)",
      ". as $orig | ($orig.key3 | map({key: .key4, value: .key5}) | from_entries) as $obj | $orig + $obj | del(.key3)"
    ],
    "data": [
      {
        "input": {
          "key1": "value1",
          "key2": "value2",
          "key3": [
            {
              "key4": "value3",
              "key5": "value5"
            },
            {
              "key4": "value4",
              "key5": "value6"
            },
            {
              "key4": "valueN",
              "key5": "valueM"
            }
          ]
        },
        "output": {
          "key1": "value1",
          "key2": "value2",
          "value3": "value5",
          "value4": "value6",
          "valueN": "valueM"
        }
      }
    ],
    "identifier": 73370258
  },
  {
    "context": [
      "I want to export the key value pair as environment variables. Basically I want to read the json above and execute commands as",
      "export PREPROCESS_GROUP_NAME='preprocess-group-name'",
      "I am looking for a solution which will create export commands based on dynamically generated keys and values.",
      "jq -r '.[] | to_entries[] | \"export \\(.key)=\\(.value|@sh)\"'"
    ],
    "utterance": "Generate shell export statements for all key-value pairs in each object, handling arbitrary key names.",
    "expressions": [
      ".[] | to_entries[] | \"export \\(.key)=\\(.value|@sh)\"",
      "jq -r '.[] | to_entries[] | \"export \\(.key)=\\(.value|@sh)\"'"
    ],
    "data": [
      {
        "input": [
          {
            "PREPROCESS_GROUP_NAME": "preprocess-group-name",
            "PREPROCESS_VERSION": 2
          },
          {
            "CLASSIFIER_GROUP_NAME": "classifier-group-name",
            "CLASSIFIER_VERSION": 2
          },
          {
            "ABC_GROUP_NAME": "abc-group-name",
            "ABC_VERSION": 2
          }
        ],
        "output": [
          "export PREPROCESS_GROUP_NAME='preprocess-group-name'",
          "export PREPROCESS_VERSION=2",
          "export CLASSIFIER_GROUP_NAME='classifier-group-name'",
          "export CLASSIFIER_VERSION=2",
          "export ABC_GROUP_NAME='abc-group-name'",
          "export ABC_VERSION=2"
        ]
      }
    ],
    "identifier": 73380979
  },
  {
    "context": [
      "I have an array of strings and I want to retrieve the one before the one matching a certain value.",
      "we have some JSON data and we want to find the element before the one specificed in $VERSION",
      "Use the `index` function to get the position:",
      "jq --arg v \"0.3.0\" -r '.versions | .[index($v) - 1]' input.json",
      "0.2.0"
    ],
    "utterance": "Return the element immediately preceding a given value (e.g., \"0.3.0\") in an array of strings under the key \"versions\".",
    "expressions": [
      ".versions | .[index($v) - 1]"
    ],
    "data": [
      {
        "input": {
          "versions": [
            "0.1.0",
            "0.2.0",
            "0.3.0",
            "0.3.1",
            "0.5.0-rc.1",
            "0.5.0"
          ]
        },
        "output": "0.2.0"
      }
    ],
    "identifier": 73389610
  },
  {
    "context": [
      "Suppose we have a JSON:\r\n```json\r\n{\r\n \"a\" : 23,\r\n \"b\" : \"hi\",\r\n \"c\": [90],\r\n \"d\": [{\"j\" : 80}]\r\n}\r\n```",
      "I want to convert this to\r\n```json\r\n{\r\n \"a\" : [23],\r\n \"b\" : [\"hi\"],\r\n \"c\": [90],\r\n \"d\": [{\"j\" : 80}]\r\n}\r\n```",
      "You could update `|=` each field `.[]` using an `if` statement based on the value's `type`:\r\n~~~sh\r\n.[] |= if type == \"array\" then . else [.] end\r\n~~~",
      "Instead of checking the `type` against `array`, you could also just update `scalars`, which are all non-iterables, i.e. no arrays and no objects:\r\n~~~sh\r\n(.[] | scalars) |= [.]\r\n~~~",
      "Please try this:\r\n\njq 'with_entries(.value|=([.]|flatten))' input.json\n"
    ],
    "utterance": "Wrap all first-level atomic values (numbers and strings) in arrays, but leave existing arrays and objects unchanged.",
    "expressions": [
      ".[] |= if type == \"array\" then . else [.] end",
      "(.[] | scalars) |= [.]",
      "with_entries(.value|=([.]|flatten))"
    ],
    "data": [
      {
        "input": {
          "a": 23,
          "b": "hi",
          "c": [
            90
          ],
          "d": [
            {
              "j": 80
            }
          ]
        },
        "output": {
          "a": [
            23
          ],
          "b": [
            "hi"
          ],
          "c": [
            90
          ],
          "d": [
            {
              "j": 80
            }
          ]
        }
      }
    ],
    "identifier": 73385429
  },
  {
    "context": [
      "I want to filter out objects in the items list that have an object in their nestedField array where `name == key1` and `value == vala`.",
      "I do want to return the full objects, but I need some way of doing a nested select statement against the objects of the `nestedFields`.",
      "Try this :",
      "jq '.items[] |\n    select(any(.nestedFieldTop.nestedField[];\n               .name == \"key1\" and .value == \"vala\"\n              )\n          )' mydata.json"
    ],
    "utterance": "Return each object in the top-level 'items' array that contains at least one object in its 'nestedFieldTop.nestedField' array where 'name' is 'key1' and 'value' is 'vala'.",
    "expressions": [
      ".items[] | select(any(.nestedFieldTop.nestedField[]; .name == \"key1\" and .value == \"vala\"))"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "topLevelField": {
                "i-want-this": "some-value1"
              },
              "nestedFieldTop": {
                "nestedField": [
                  {
                    "name": "key1",
                    "value": "val1"
                  },
                  {
                    "name": "key2",
                    "value": "val2"
                  },
                  {
                    "name": "key3",
                    "someOtherProperty": "sdfsdfdsf"
                  }
                ]
              }
            },
            {
              "topLevelField": {
                "i-want-this": "some-value2"
              },
              "nestedFieldTop": {
                "nestedField": [
                  {
                    "name": "key1",
                    "value": "vala"
                  },
                  {
                    "name": "keyb",
                    "value": "valb"
                  },
                  {
                    "name": "key3",
                    "someOtherProperty": "sdfsdfdsf"
                  }
                ]
              }
            }
          ]
        },
        "output": {
          "topLevelField": {
            "i-want-this": "some-value2"
          },
          "nestedFieldTop": {
            "nestedField": [
              {
                "name": "key1",
                "value": "vala"
              },
              {
                "name": "keyb",
                "value": "valb"
              },
              {
                "name": "key3",
                "someOtherProperty": "sdfsdfdsf"
              }
            ]
          }
        }
      }
    ],
    "identifier": 73381008
  },
  {
    "context": [
      "I have multiple files containing both A array elements at the top level, and files containing A array elements nested in B elements. Is it possible to extract the data in a single jq line?",
      "File 1:\n{\n  \"A\" : [ \n    { \"x\" : \" y\" } \n    ] \n}",
      "File 2:\n{\n  \"B\" : [ \n    { \"A\" : [ \n      { \"x\" : \"y\" } \n    ] } \n] }",
      "jq -r 'select(.A[] != null or .B[].A[] != null) | .A[] | .x'",
      "getpath(paths | select(.[-1] == \"A\")) | .[].x",
      "getpath(paths | select(.[-3] == \"A\" and .[-1] == \"x\"))",
      "jq -r '., .B[]? | .A[]?.x'"
    ],
    "utterance": "Extract all values of x from A arrays whether they are at the top level or nested inside B elements.",
    "expressions": [
      "getpath(paths | select(.[-1] == \"A\")) | .[].x",
      "getpath(paths | select(.[-3] == \"A\" and .[-1] == \"x\"))",
      "., .B[]? | .A[]?.x"
    ],
    "data": [
      {
        "input": {
          "A": [
            {
              "x": " y"
            }
          ]
        },
        "output": [
          " y"
        ]
      },
      {
        "input": {
          "B": [
            {
              "A": [
                {
                  "x": "y"
                }
              ]
            }
          ]
        },
        "output": [
          "y"
        ]
      }
    ],
    "identifier": 73399140
  },
  {
    "context": [
      "Is there some fancy expression I can add to my jq query to output each object individually in a subdirectory, keyed by the `id`, in the form `id/id.json`? For example `current-directory/foo/foo.json` and `current-directory/bar/bar.json`?",
      "As @pmf has pointed out, an \"only-jq\" solution is not possible.  A solution using jq and awk is as follows, though it is far from robust:",
      "<input.json jq -rc '.id, .' | awk '\n  id==\"\" {id=$0; next;}\n  { path=id; gsub(/[/]/, \"_\", path);\n    system(\"mkdir -p \" path);\n    print >> path \"/\" id \".json\";\n    id=\"\";\n  }\n'"
    ],
    "utterance": "Write each object to a separate file inside a subdirectory named after its id, with the file named id.json",
    "expressions": [
      ".id, ."
    ],
    "data": [
      {
        "input": [
          {
            "id": "foo",
            "value": "123"
          },
          {
            "id": "bar",
            "value": "456"
          }
        ],
        "output": [
          "foo/foo.json -> { \"id\": \"foo\", \"value\": \"123\" }",
          "bar/bar.json -> { \"id\": \"bar\", \"value\": \"456\" }"
        ]
      }
    ],
    "identifier": 73407028
  },
  {
    "context": [
      "I want to extract `Arn`, `DefaultVersionId` from following JSON where `Arn` string contains word *akshay*:",
      "When tried with following, I just get the `Arn` and not `DefaultVersionId`:",
      ".[] | .Arn, .DefaultVersionId | select(contains(\"akshay\"))",
      "You need to filter the required objects first (based on your condition) and then extract the fields needed, i.e.",
      "map( select( .Arn | contains( \"akshay\" ) )? )[] | .Arn, .DefaultVersionId",
      "To get the values on the same line separated by a single whitespace use \"\\(.Arn) \\(.DefaultVersionId)\" after the pipe symbol.",
      "Note that `contains` looks for an exact match of the search string and does _not_ satisfy case insensitivity. To do so use `test(\"akshay\"; \"i\")` instead."
    ],
    "utterance": "Extract Arn and DefaultVersionId for all objects where Arn contains the word akshay.",
    "expressions": [
      "map(select(.Arn | contains(\"akshay\")))[] | .Arn, .DefaultVersionId",
      "map(select(.Arn | contains(\"akshay\")))[] | \"\\(.Arn) \\(.DefaultVersionId)\"",
      "map(select(.Arn | test(\"akshay\"; \"i\")))[] | .Arn, .DefaultVersionId",
      "map(select(.Arn | test(\"akshay\"; \"i\")))[] | \"\\(.Arn) \\(.DefaultVersionId)\""
    ],
    "data": [
      {
        "input": [
          {
            "PolicyName": "my-buckets-all",
            "PolicyId": "ABCDEF",
            "Arn": "arn:aws:iam::12345:policy/my-buckets-all",
            "Path": "/",
            "DefaultVersionId": "v1",
            "AttachmentCount": 0,
            "PermissionsBoundaryUsageCount": 0,
            "IsAttachable": true,
            "CreateDate": "2022-05-14T01:17:13+00:00",
            "UpdateDate": "2022-05-14T01:17:13+00:00"
          },
          {
            "PolicyName": "akshay-buckets-all",
            "PolicyId": "GHIJK",
            "Arn": "arn:aws:iam::12345:policy/akshay-buckets-all",
            "Path": "/",
            "DefaultVersionId": "v4",
            "AttachmentCount": 1,
            "PermissionsBoundaryUsageCount": 0,
            "IsAttachable": true,
            "CreateDate": "2022-05-20T21:20:10+00:00",
            "UpdateDate": "2022-07-28T19:15:09+00:00"
          }
        ],
        "output": [
          "arn:aws:iam::12345:policy/akshay-buckets-all",
          "v4"
        ]
      }
    ],
    "identifier": 73386307
  },
  {
    "context": [
      "I am trying to use *jq* to print out only the *login* and *contributions* field but into one line like so:",
      "Expected Result",
      "anthonyd-cd 5",
      "eljoeyjojo 2",
      "You are using the iterator `.[]` twice, so each field is extracted from a different iteration. Pull the iterator up front and extract from the context of an iteration step. Then you can use various methods to combine those, one being string interpolation `\"\\(...)\"`.",
      "jq -r '.[] | \"\\(.login) \\(.contributions)\"'",
      "anthonyd-cd 5",
      "elJoeyJojo 2"
    ],
    "utterance": "Print each object's login and contributions fields together on one line, separated by a space.",
    "expressions": [
      ".[] | \"\u0000(.login) \u0000(.contributions)\""
    ],
    "data": [
      {
        "input": [
          {
            "login": "anthonyd-cd",
            "id": 35614549,
            "node_id": "MDQ6VXNlcjM1NjE0NTQ5",
            "avatar_url": "https://avatars.githubusercontent.com/u/35614549?v=4",
            "gravatar_id": "",
            "url": "https://api.github.com/users/anthonyd-cd",
            "html_url": "https://github.com/anthonyd-cd",
            "followers_url": "https://api.github.com/users/anthonyd-cd/followers",
            "following_url": "https://api.github.com/users/anthonyd-cd/following{/other_user}",
            "gists_url": "https://api.github.com/users/anthonyd-cd/gists{/gist_id}",
            "starred_url": "https://api.github.com/users/anthonyd-cd/starred{/owner}{/repo}",
            "subscriptions_url": "https://api.github.com/users/anthonyd-cd/subscriptions",
            "organizations_url": "https://api.github.com/users/anthonyd-cd/orgs",
            "repos_url": "https://api.github.com/users/anthonyd-cd/repos",
            "events_url": "https://api.github.com/users/anthonyd-cd/events{/privacy}",
            "received_events_url": "https://api.github.com/users/anthonyd-cd/received_events",
            "type": "User",
            "site_admin": false,
            "contributions": 5
          },
          {
            "login": "elJoeyJojo",
            "id": 17091968,
            "node_id": "MDQ6VXNlcjE3MDkxOTY4",
            "avatar_url": "https://avatars.githubusercontent.com/u/17091968?v=4",
            "gravatar_id": "",
            "url": "https://api.github.com/users/elJoeyJojo",
            "html_url": "https://github.com/elJoeyJojo",
            "followers_url": "https://api.github.com/users/elJoeyJojo/followers",
            "following_url": "https://api.github.com/users/elJoeyJojo/following{/other_user}",
            "gists_url": "https://api.github.com/users/elJoeyJojo/gists{/gist_id}",
            "starred_url": "https://api.github.com/users/elJoeyJojo/starred{/owner}{/repo}",
            "subscriptions_url": "https://api.github.com/users/elJoeyJojo/subscriptions",
            "organizations_url": "https://api.github.com/users/elJoeyJojo/orgs",
            "repos_url": "https://api.github.com/users/elJoeyJojo/repos",
            "events_url": "https://api.github.com/users/elJoeyJojo/events{/privacy}",
            "received_events_url": "https://api.github.com/users/elJoeyJojo/received_events",
            "type": "User",
            "site_admin": false,
            "contributions": 2
          }
        ],
        "output": [
          "anthonyd-cd 5",
          "elJoeyJojo 2"
        ]
      }
    ],
    "identifier": 73392280
  },
  {
    "context": [
      "From a jq filter from which i get output like below\n\n````\n{\"name\": \"xyz\", \"age\": 12}\n{\"name\": \"123\", \"age\": 19}\n````\n\nBut I would like to transform like below\n\n````\n{\"val\" : [\n          {\"name\": \"xyz\", \"age\": 12},\n          {\"name\": \"123\", \"age\": 19}\n         ]\n}\n````",
      "If your input file consists of a stream of objects, use `inputs` in combination with the `--null-input` (or `-n`) flag:\n~~~sh\njq -n '{val: [inputs]}'\n~~~",
      "But if you have a previous filter that produces a stream, you need to tweak that to produce an array instead (often it suffices to wrap all the previous filter in square brackets, but if you generally need help with that as well you should provide it in the question)."
    ],
    "utterance": "Combine multiple top-level objects into a single object with one array field called 'val' containing all the original objects.",
    "expressions": [
      "{val: [inputs]}"
    ],
    "data": [
      {
        "input": [
          {
            "name": "xyz",
            "age": 12
          },
          {
            "name": "123",
            "age": 19
          }
        ],
        "output": {
          "val": [
            {
              "name": "xyz",
              "age": 12
            },
            {
              "name": "123",
              "age": 19
            }
          ]
        }
      }
    ],
    "identifier": 73400031
  },
  {
    "context": [
      "How can I sort the sub-objects by a different property of theirs (i.e. `date` in the above example), when serializing this JSON?",
      "`jq 'to_entries | sort_by(.value.date) | from_entries'`"
    ],
    "utterance": "Sort the top-level object's entries by the 'date' property of its sub-objects.",
    "expressions": [
      "to_entries | sort_by(.value.date) | from_entries"
    ],
    "data": [
      {
        "input": {
          "Foo": {
            "name": "Foo",
            "date": "2022-08-21"
          },
          "Bar": {
            "name": "Bar",
            "date": "2022-08-20"
          }
        },
        "output": {
          "Bar": {
            "name": "Bar",
            "date": "2022-08-20"
          },
          "Foo": {
            "name": "Foo",
            "date": "2022-08-21"
          }
        }
      }
    ],
    "identifier": 73438077
  },
  {
    "context": [
      "I have initial json data, as array of collected data points for graph (arrays) - first is a timestamp, second is some everincreasing value, collected over time (lets say, h2o level)",
      "[[1,5.5],[2,5.6],[3,5.9],[4,6.9]]",
      "I want to find derivative of second changing value, over time, in jq.",
      "so with given offset = -1 it should produce output\n```\n[[2,0.1],[3,0.3],[4,1.0]]\n```\n",
      "You could generate two subsets based on the offset, then subtract each corresponding element using `transpose` and `map`:",
      "(-1) as $offset\n| [.[-$offset:], .[:$offset]] | transpose | map(.[0][1] -= .[1][1] | .[0])",
      "Alternatively, use a `range` to iterate over the indices, and build the new array successively:",
      "(-1) as $offset\n| [range(-$offset; length) as $i | [.[$i][0], .[$i][1] - .[$i + $offset][1]]]",
      "Here's a generic \"derivative\" function yielding a declarative one-line solution (apart of course from the `def` itself):",
      "def derivative(delta; p):\n  . as $in\n  | [ range(delta; length) as $i\n      | .[$i]\n      | (p = ($in[$i] | p) - ($in[$i - delta] | p)) ];\n\nderivative(1; .[1])"
    ],
    "utterance": "Calculate the difference in the second value between consecutive data points and pair it with the timestamp of the latter point, using an offset of -1.",
    "expressions": [
      "(-1) as $offset | [.[-$offset:], .[:$offset]] | transpose | map(.[0][1] -= .[1][1] | .[0])",
      "(-1) as $offset | [range(-$offset; length) as $i | [.[$i][0], .[$i][1] - .[$i + $offset][1]]]",
      "def derivative(delta; p): . as $in | [ range(delta; length) as $i | .[$i] | (p = ($in[$i] | p) - ($in[$i - delta] | p)) ]; derivative(1; .[1])"
    ],
    "data": [
      {
        "input": [
          [
            1,
            5.5
          ],
          [
            2,
            5.6
          ],
          [
            3,
            5.9
          ],
          [
            4,
            6.9
          ]
        ],
        "output": [
          [
            2,
            0.1
          ],
          [
            3,
            0.3
          ],
          [
            4,
            1.0
          ]
        ]
      }
    ],
    "identifier": 73402757
  },
  {
    "context": [
      "I want to add an extra field to the child object containing a value from the parent, e.g.",
      "Use the update operator `|=` to retain the contexts while storing the `.name` values in variables using `as`:\n~~~sh\n.tables[] |= (\n  .name as $tname | .fields[] |= (\n    .name as $fname | .fqn = \"\\($tname)_\\($fname)\"\n  )\n)\n~~~",
      "The following is equivalent to @pmf's solution but is perhaps a little less magical (it uses `map` as suggested in the question), and only introduces one variable:\n\n``` \n.tables |= map( .name as $name | .fields |= map( .fqn = \"\\($name)_\\(.name)\" ))\n```"
    ],
    "utterance": "For each field in each table, add an 'fqn' property combining the parent table's name and the field's name separated by an underscore.",
    "expressions": [
      ".tables[] |= (.name as $tname | .fields[] |= (.name as $fname | .fqn = \"\\($tname)_\\($fname)\"))",
      ".tables |= map( .name as $name | .fields |= map( .fqn = \"\\($name)_\\(.name)\" ))"
    ],
    "data": [
      {
        "input": {
          "tables": [
            {
              "name": "TableA",
              "fields": [
                {
                  "name": "FieldA"
                },
                {
                  "name": "FieldB"
                }
              ]
            },
            {
              "name": "TableB",
              "fields": [
                {
                  "name": "FieldA"
                },
                {
                  "name": "FieldB"
                }
              ]
            }
          ]
        },
        "output": {
          "tables": [
            {
              "name": "TableA",
              "fields": [
                {
                  "name": "FieldA",
                  "fqn": "TableA_FieldA"
                },
                {
                  "name": "FieldB",
                  "fqn": "TableA_FieldB"
                }
              ]
            },
            {
              "name": "TableB",
              "fields": [
                {
                  "name": "FieldA",
                  "fqn": "TableB_FieldA"
                },
                {
                  "name": "FieldB",
                  "fqn": "TableB_FieldB"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 73432115
  },
  {
    "context": [
      "I need to replace keys according some format with values \u200b\u200bfrom other keys whose \u200b\u200bare in strings of some array.",
      "Desired output:",
      "{\r\n\"A\": 100, \r\n\"B\": 200, \r\n\"C\": \"ccc\",\r\n\"R1\": {\"R3\": \"100::200::baz\"},\r\n\"R2\": {\"R4\": \"100/ccc\"}\r\n}",
      "Edit: As the question has been modified with the `.result` value now also being subject to reference interpretation, measures taken for `.vals` therefore apply to it as well. This implies changing the suggested source document format to use path expressions as in `\"result\": [\"R1\", \"R3\"]`, and changing the assignment in the suggested code from `.[$a.result] = ...` to `setpath($a.result; ...)`:",
      ". as $top | reduce .arr[] as $a (del(.arr); setpath($a.result;\n  reduce $a.vals[] as $path ($a.fmt; sub(\"%s\"; $top | getpath($path) | @text))\n))"
    ],
    "utterance": "Replace entries in an array by formatting strings using values from referenced keys, assigning the result to an object path specified in the array.",
    "expressions": [
      ". as $top | reduce .arr[] as $a (del(.arr); setpath($a.result;\n  reduce $a.vals[] as $path ($a.fmt; sub(\"%s\"; $top | getpath($path) | @text))\n))"
    ],
    "data": [
      {
        "input": {
          "A": 100,
          "B": 200,
          "C": "ccc",
          "arr": [
            {
              "result": [
                "R1",
                "R3"
              ],
              "fmt": "%s::%s::baz",
              "vals": [
                [
                  "A"
                ],
                [
                  "B"
                ]
              ]
            },
            {
              "result": [
                "R2",
                "R4"
              ],
              "fmt": "%s/%s",
              "vals": [
                [
                  "A"
                ],
                [
                  "C"
                ]
              ]
            }
          ]
        },
        "output": {
          "A": 100,
          "B": 200,
          "C": "ccc",
          "R1": {
            "R3": "100::200::baz"
          },
          "R2": {
            "R4": "100/ccc"
          }
        }
      }
    ],
    "identifier": 73432716
  },
  {
    "context": [
      "I have a JSON output like the one below and need to find the value of **appId** of the exact match of **\"name\": \"exampleAppName01\"** using JQ.",
      "Simply I need to find the appId if the name matches what we provide."
    ],
    "utterance": "Find the appId of the entry whose name is exactly \"exampleAppName01\".",
    "expressions": [
      ".apps[] | select(.name == \"exampleAppName01\") | .appId"
    ],
    "data": [
      {
        "input": {
          "apps": [
            {
              "appId": "exampleAppID01",
              "appArn": "arn:aws:amplify:eu-west-1:xxxxxxxxxxxxx:apps/exampleAppID01",
              "name": "exampleAppName01",
              "tags": {
                "pci_scope": "none",
                "project": "exampleRepoName01",
                "environment": "dev-default",
                "workspace": "default",
                "terraform": "true"
              },
              "description": "Amplify App for the exapmle project.",
              "platform": "WEB_DYNAMIC",
              "createTime": "2022-08-09T12:26:10.472000+05:30",
              "updateTime": "2022-08-16T13:18:31.658000+05:30",
              "iamServiceRoleArn": "arn:aws:iam::xxxxxxxxxxxxx:role/exampleAppName01-role",
              "environmentVariables": {
                "APP_DEBUG": "true",
                "_LIVE_UPDATES": "[{\"pkg\":\"@aws-amplify/cli\",\"type\":\"npm\",\"version\":\"latest\"},{\"pkg\":\"next-version\",\"type\":\"internal\",\"version\":\"latest\"},{\"pkg\":\"yarn\",\"type\":\"npm\",\"version\":\"latest\"},{\"pkg\":\"node\",\"type\":\"nvm\",\"version\":\"16.13.0\"}]"
              },
              "defaultDomain": "exampleAppID01.amplifyapp.com",
              "enableBranchAutoBuild": true,
              "enableBranchAutoDeletion": true,
              "enableBasicAuth": false,
              "customRules": [
                {
                  "source": "/<*>",
                  "target": "https://xxxxxxxxxxxx.cloudfront.net/<*>",
                  "status": "200"
                },
                {
                  "source": "/<*>",
                  "target": "https://xxxxxxxxxxxx.cloudfront.net/<*>",
                  "status": "200"
                },
                {
                  "source": "/<*>",
                  "target": "https://xxxxxxxxxxxx.cloudfront.net/<*>",
                  "status": "200"
                }
              ],
              "buildSpec": "version: 1\nbackend:\n  phases:\n    build:\n      commands:\n        - '# Execute Amplify CLI with the helper script'\n        - amplifyPush --simple\nfrontend:\n  phases:\n    preBuild:\n      commands:\n        - yarn install\n    build:\n      commands:\n        - yarn run lint\n        - yarn run build\n  artifacts:\n    baseDirectory: .next\n    files:\n      - '**/*'\n  cache:\n    paths:\n      - node_modules/**/*\ntest:\n  artifacts:\n    baseDirectory: cypress\n    configFilePath: '**/mochawesome.json'\n    files:\n      - '**/*.png'\n      - '**/*.mp4'\n  phases:\n    preTest:\n      commands:\n        - echo \"test\"\n#test:\n#  artifacts:\n#    baseDirectory: cypress\n#    configFilePath: '**/mochawesome.json'\n#    files:\n#      - '**/*.png'\n#      - '**/*.mp4'\n#  phases:\n#    preTest:\n#      commands:\n#        - npm install\n#        - npm install start-server-and-test cypress mocha mochawesome mochawesome-merge mochawesome-report-generator --save-dev\n#    test:\n#      commands:\n#        # We need to set the NEXTAUTH_URL to localhost for the cypress tests but leave them as they were coming from the set environment variables for the deployed app\n#        - NEXTAUTH_URL=http://localhost:3000\n#        - npm run build\n#        - npx start-test 'yarn start' 3000 'npx cypress run --reporter mochawesome --reporter-options \"reportDir=cypress/report/mochawesome-report,overwrite=false,html=false,json=true,timestamp=mmddyyyy_HHMMss\"'\n#    postTest:\n#      commands:\n#        - npx mochawesome-merge cypress/report/mochawesome-report/mochawesome*.json > cypress/report/mochawesome.json\n",
              "customHeaders": "",
              "enableAutoBranchCreation": true,
              "autoBranchCreationPatterns": [
                "example-*"
              ],
              "autoBranchCreationConfig": {
                "stage": "NONE",
                "enableAutoBuild": true,
                "environmentVariables": {},
                "enableBasicAuth": false,
                "enablePullRequestPreview": false
              },
              "repositoryCloneMethod": "SSH"
            },
            {
              "appId": "exampleAppID02",
              "appArn": "arn:aws:amplify:eu-west-1:xxxxxxxxxxxxx:apps/exampleAppID02",
              "name": "exampleAppName02",
              "tags": {
                "pci_scope": "none",
                "project": "exampleRepoName02",
                "environment": "dev-default",
                "workspace": "default",
                "terraform": "true"
              },
              "description": "Amplify App for the exapmle project.",
              "platform": "WEB_DYNAMIC",
              "createTime": "2022-08-09T12:26:10.472000+05:30",
              "updateTime": "2022-08-16T13:18:31.658000+05:30",
              "iamServiceRoleArn": "arn:aws:iam::xxxxxxxxxxxxx:role/exampleAppName02-role",
              "environmentVariables": {
                "APP_DEBUG": "true",
                "_LIVE_UPDATES": "[{\"pkg\":\"@aws-amplify/cli\",\"type\":\"npm\",\"version\":\"latest\"},{\"pkg\":\"next-version\",\"type\":\"internal\",\"version\":\"latest\"},{\"pkg\":\"yarn\",\"type\":\"npm\",\"version\":\"latest\"},{\"pkg\":\"node\",\"type\":\"nvm\",\"version\":\"16.13.0\"}]"
              },
              "defaultDomain": "exampleAppID02.amplifyapp.com",
              "enableBranchAutoBuild": true,
              "enableBranchAutoDeletion": true,
              "enableBasicAuth": false,
              "customRules": [
                {
                  "source": "/<*>",
                  "target": "https://xxxxxxxxxxxx.cloudfront.net/<*>",
                  "status": "200"
                },
                {
                  "source": "/<*>",
                  "target": "https://xxxxxxxxxxxx.cloudfront.net/<*>",
                  "status": "200"
                },
                {
                  "source": "/<*>",
                  "target": "https://xxxxxxxxxxxx.cloudfront.net/<*>",
                  "status": "200"
                }
              ],
              "buildSpec": "version: 1\nbackend:\n  phases:\n    build:\n      commands:\n        - '# Execute Amplify CLI with the helper script'\n        - amplifyPush --simple\nfrontend:\n  phases:\n    preBuild:\n      commands:\n        - yarn install\n    build:\n      commands:\n        - yarn run lint\n        - yarn run build\n  artifacts:\n    baseDirectory: .next\n    files:\n      - '**/*'\n  cache:\n    paths:\n      - node_modules/**/*\ntest:\n  artifacts:\n    baseDirectory: cypress\n    configFilePath: '**/mochawesome.json'\n    files:\n      - '**/*.png'\n      - '**/*.mp4'\n  phases:\n    preTest:\n      commands:\n        - echo \"test\"\n#test:\n#  artifacts:\n#    baseDirectory: cypress\n#    configFilePath: '**/mochawesome.json'\n#    files:\n#      - '**/*.png'\n#      - '**/*.mp4'\n#  phases:\n#    preTest:\n#      commands:\n#        - npm install\n#        - npm install start-server-and-test cypress mocha mochawesome mochawesome-merge mochawesome-report-generator --save-dev\n#    test:\n#      commands:\n#        # We need to set the NEXTAUTH_URL to localhost for the cypress tests but leave them as they were coming from the set environment variables for the deployed app\n#        - NEXTAUTH_URL=http://localhost:3000\n#        - npm run build\n#        - npx start-test 'yarn start' 3000 'npx cypress run --reporter mochawesome --reporter-options \"reportDir=cypress/report/mochawesome-report,overwrite=false,html=false,json=true,timestamp=mmddyyyy_HHMMss\"'\n#    postTest:\n#      commands:\n#        - npx mochawesome-merge cypress/report/mochawesome-report/mochawesome*.json > cypress/report/mochawesome.json\n",
              "customHeaders": "",
              "enableAutoBranchCreation": true,
              "autoBranchCreationPatterns": [
                "example-*"
              ],
              "autoBranchCreationConfig": {
                "stage": "NONE",
                "enableAutoBuild": true,
                "environmentVariables": {},
                "enableBasicAuth": false,
                "enablePullRequestPreview": false
              },
              "repositoryCloneMethod": "SSH"
            }
          ]
        },
        "output": "exampleAppID01"
      }
    ],
    "identifier": 73441778
  }
]