[
  {
    "context": [
      "mypath=\"level1.level2.level3\"",
      "jq '.level1.level2.level3' $myfile",
      "jq --arg nest \"$mypath\" '.[$nest]' $myfile",
      "You need [`getpath/1`][1] for this. The method takes an array of paths to a particular node and returns the value present at it",
      "jq --arg nest \"$mypath\" 'getpath($nest|split(\".\"))'"
    ],
    "utterance": "Access a deeply nested value at a variable path specified as a dot-separated string such as 'level1.level2.level3', supplied via an argument.",
    "expressions": [
      "getpath($nest|split(\".\"))"
    ],
    "data": [
      {
        "input": {
          "level1": {
            "level2": {
              "level3": "value"
            }
          }
        },
        "output": "value"
      }
    ],
    "identifier": 72127865
  },
  {
    "context": [
      "cat test.json | jq 'select(.record.key_B=\"oranges\")'",
      "I wish it would only output the record which match the select - the ones where .record.key_B = oranges so only the first record.",
      "`=` is an assignment operator. `==` is an equality-comparison operator.",
      "You want `select(.record.key_B == \"oranges\")`."
    ],
    "utterance": "Filter records where the value of key_B is oranges.",
    "expressions": [
      "select(.record.key_B == \"oranges\")"
    ],
    "data": [
      {
        "input": [
          {
            "type": "RECORD",
            "record": {
              "key_A": "apples",
              "key_B": "bananas"
            }
          },
          {
            "type": "RECORD",
            "record": {
              "key_A": "apples",
              "key_B": "oranges"
            }
          }
        ],
        "output": [
          {
            "type": "RECORD",
            "record": {
              "key_A": "apples",
              "key_B": "oranges"
            }
          }
        ]
      }
    ],
    "identifier": 72164700
  },
  {
    "context": [
      "Expected result",
      "",
      "name1,16590879,0.043984349",
      "name1,16590876,0.043983444",
      "jq -r '[.metric.name] + .values[] | @csv'",
      "\"name1\",16590879,\"0.043984349\"",
      "\"name1\",16590876,\"0.043983444\""
    ],
    "utterance": "For each subarray in values, output a CSV line with metric.name as the first column followed by the elements of the subarray.",
    "expressions": [
      "[.metric.name] + .values[] | @csv"
    ],
    "data": [
      {
        "input": {
          "metric": {
            "name": "name1"
          },
          "values": [
            [
              16590879,
              "0.043984349"
            ],
            [
              16590876,
              "0.043983444"
            ]
          ]
        },
        "output": [
          "\"name1\",16590879,\"0.043984349\"",
          "\"name1\",16590876,\"0.043983444\""
        ]
      }
    ],
    "identifier": 72128929
  },
  {
    "context": [
      "jq: error (at <stdin>:1): null (null) cannot be matched, as it is not a string",
      "What is the most succinct way to fix the error so that .y is still accessed with \",\" replaced by \"-\", but when .y does not exist, an empty string will be printed?",
      "jq '.y | gsub(\",\"; \"-\")? // \"\"'"
    ],
    "utterance": "Replace all commas with dashes in the value at key y, and if y does not exist, output an empty string.",
    "expressions": [
      ".y | gsub(\",\"; \"-\")? // \"\""
    ],
    "data": [
      {
        "input": {
          "y": "a,b"
        },
        "output": "a-b"
      },
      {
        "input": {
          "x": "a"
        },
        "output": ""
      }
    ],
    "identifier": 72148717
  },
  {
    "context": [
      "The desire output is:",
      "{\r\n  \"op\": \"add\",\r\n  \"path\": \"/support\",\r\n  \"apiSupports\": [\r\n    {\r\n      \"familyType\": \"EXAMPLE\",\r\n      \"healthCheckUris\": \"http://example.com\"\r\n    }\r\n  ],\r\n  \"inboundurls\": [\r\n    {\r\n      \"healthCheckUris\": \"http://example.com\"\r\n    }\r\n  ]\r\n}",
      "jq -n --arg op \"add\" \\\r\n   --arg path \"/support\" \\\r\n   --arg familyType EXAMPLE \\\r\n   --arg healthCheckUris http://example.com '\r\n   {$op, $path, \r\n    apiSupports: [ {$familyType, $healthCheckUris }],\r\n    inboundurls: [ {$healthCheckUris }]\r\n }\r\n'"
    ],
    "utterance": "Produce a nested object with keys 'op' as 'add', 'path' as '/support', 'apiSupports' containing an object with 'familyType' as 'EXAMPLE' and 'healthCheckUris' as 'http://example.com', and 'inboundurls' containing an object with 'healthCheckUris' as 'http://example.com'.",
    "expressions": [
      "jq -n --arg op \"add\" \\\n   --arg path \"/support\" \\\n   --arg familyType EXAMPLE \\\n   --arg healthCheckUris http://example.com '\n   {$op, $path, \n    apiSupports: [ {$familyType, $healthCheckUris }],\n    inboundurls: [ {$healthCheckUris }]\n }'"
    ],
    "data": [
      {
        "input": null,
        "output": {
          "op": "add",
          "path": "/support",
          "apiSupports": [
            {
              "familyType": "EXAMPLE",
              "healthCheckUris": "http://example.com"
            }
          ],
          "inboundurls": [
            {
              "healthCheckUris": "http://example.com"
            }
          ]
        }
      }
    ],
    "identifier": 72133488
  },
  {
    "context": [
      "I can't manage to filter it in such a way that I can get the names of the books that \"availability\" is equal to true.",
      "Note for example that book-name-3 does not have that variable and book-name-2 has it set to false.",
      "So, the output I expect to get after filtering is:",
      "book-name-1,\nbook-name-4",
      "jq -r '.books | .[] |= select(.availability) | keys_unsorted[]'",
      "jq -r '.books | to_entries[] | select(.value.availability).key'",
      "To also feature the commas, you could leave it as array, and use a join(\",\\n\") to combine:"
    ],
    "utterance": "List the keys of all books where availability is true, skipping books where the field is missing or false.",
    "expressions": [
      ".books | to_entries[] | select(.value.availability).key",
      ".books | to_entries | map(select(.value.availability)) | map(.key) | join(\",\\n\")"
    ],
    "data": [
      {
        "input": {
          "books": {
            "book-name-1": {
              "path": "management/business",
              "availability": true,
              "vars": {
                "author": "John",
                "year": "2005"
              }
            },
            "book-name-2": {
              "path": "engineering/computing",
              "availability": false,
              "vars": {
                "author": "Rick",
                "year": "2010"
              }
            },
            "book-name-3": {
              "path": "finance/general",
              "vars": {
                "author": "Joe",
                "year": "2020"
              }
            },
            "book-name-4": {
              "path": "medicine/general",
              "availability": true,
              "vars": {
                "author": "Stacy",
                "year": "2018"
              }
            }
          }
        },
        "output": [
          "book-name-1",
          "book-name-4"
        ]
      }
    ],
    "identifier": 72147637
  },
  {
    "context": [
      "Is there a way to return the object that contains that grep match? So it should return \n\n    {\n      \"first_fruit\": \"apples\",\n      \"second_fruit\": \"bananas\"\n    } ",
      "{first_fruit: .record.key_A,second_fruit:.record.key_B}\n  | select(any(.[]; . == \"bananas\"))",
      ".record | select(any(.[]; . == \"bananas\"))\n| {first_fruit: .key_A, second_fruit: .key_B}",
      "Instead of finding exact matches with ==, you can also use contains for partial matches, or test for a full regex test.\nselect(any(.[]; contains(\"bananas\")))",
      "select(any(.[]; test(\"bananas\")))"
    ],
    "utterance": "Return the constructed object with keys first_fruit and second_fruit only if any field value equals 'bananas'.",
    "expressions": [
      "{first_fruit: .record.key_A, second_fruit: .record.key_B} | select(any(.[]; . == \"bananas\"))",
      ".record | select(any(.[]; . == \"bananas\")) | {first_fruit: .key_A, second_fruit: .key_B}",
      "{first_fruit: .record.key_A, second_fruit: .record.key_B} | select(any(.[]; contains(\"bananas\")))",
      "{first_fruit: .record.key_A, second_fruit: .record.key_B} | select(any(.[]; test(\"bananas\")))"
    ],
    "data": [
      {
        "input": {
          "type": "RECORD",
          "record": {
            "key_A": "apples",
            "key_B": "bananas"
          }
        },
        "output": {
          "first_fruit": "apples",
          "second_fruit": "bananas"
        }
      }
    ],
    "identifier": 72164489
  },
  {
    "context": [
      "I expect output\n[1,2]\n[3,4]",
      "keys='[[\"key1\",\"a\"],[\"key2\",\"b\"]]' ; jq -c -n --argjson keys \"$keys\" '$keys'",
      "keys='[[\"key1\",\"a\"],[\"key2\",\"b\"]]' jq -c -n 'env.keys | fromjson'"
    ],
    "utterance": "Extract the values at paths [\"key1\",\"a\"] and [\"key2\",\"b\"] from each object in an array and output them as arrays.",
    "expressions": [
      ".[] | [getpath([\"key1\",\"a\"]), getpath([\"key2\",\"b\"])]",
      ".[] | [getpath($keys[])]"
    ],
    "data": [
      {
        "input": [
          {
            "key1": {
              "a": 1
            },
            "key2": {
              "b": 2
            }
          },
          {
            "key1": {
              "a": 3
            },
            "key2": {
              "b": 4
            }
          }
        ],
        "output": [
          [
            1,
            2
          ],
          [
            3,
            4
          ]
        ]
      }
    ],
    "identifier": 72166959
  },
  {
    "context": [
      "$ jq -nf &lt;(echo \\&quot;hello world\\&quot;)",
      "But when I try",
      "$ jq -nf &lt;&lt;&lt;$&#39;\\&quot;hello world\\&quot;&#39;",
      "this fails with error",
      "jq: Could not open .: It&#39;s a directory",
      "jq -nf /dev/stdin &lt;&lt;&lt;$&#39;\\&quot;hello world\\&quot;&#39;",
      "echo \\&quot;hello world\\&quot; | jq -nf /dev/stdin"
    ],
    "utterance": "Use the -f option to read a jq program from a string provided via standard input rather than a file.",
    "expressions": [
      "jq -nf /dev/stdin <<< '\"hello world\"'",
      "echo '\"hello world\"' | jq -nf /dev/stdin"
    ],
    "identifier": 72167883
  },
  {
    "context": [
      "trying to get a listing from the data pulling certain values like the listing below:\n\nhost-name-test.com, Google.com, POST, HTTPS",
      "jq -r '.services[] | .host + \" \" + (.routes[].hosts | join(\",\"))'",
      "jq -r '.services[] | \"\\(.host) \\(.routes[].hosts|join(\",\"))\"'"
    ],
    "utterance": "List each service's host, the hosts from each of its routes, the HTTP methods, and the protocol in the format: host, route host, method, protocol.",
    "expressions": [
      ".services[] | .routes[] | \"\u007f(.host), \u007f(.hosts[]), \u007f(.methods[]), \u007f(.protocols[] | ascii_upcase)\"",
      ".services[] | .routes[] | \"\u007f(.host), \u007f(.hosts | join(\", \")), \u007f(.methods | join(\", \")), \u007f(.protocols[] | ascii_upcase)\""
    ],
    "data": [
      {
        "input": {
          "_format_version": "1.1",
          "_workspace": "test",
          "services": [
            {
              "connect_timeout": 60000,
              "host": "host-name-test.com",
              "name": "name-of-service",
              "path": "/test/oauthpass",
              "port": 777,
              "protocol": "http",
              "read_timeout": 1000,
              "retries": 1,
              "write_timeout": 1000,
              "routes": [
                {
                  "hosts": [
                    "Google.com"
                  ],
                  "name": "com.testing.active.oauth",
                  "methods": [
                    "POST"
                  ],
                  "paths": [
                    "/vendors/otest/pass/?$"
                  ],
                  "path_handling": "v8",
                  "preserve_host": false,
                  "protocols": [
                    "https"
                  ],
                  "regex_priority": 0,
                  "strip_path": true,
                  "https_redirect_status_code": 426,
                  "request_buffering": true,
                  "response_buffering": true
                }
              ]
            }
          ]
        },
        "output": [
          "host-name-test.com, Google.com, POST, HTTPS"
        ]
      }
    ],
    "identifier": 72129329
  },
  {
    "context": [
      "I have been trying to extract the value of the `tf-name` key for 30 minutes ... how do I get `tmp` as a a result?",
      ".ResourceTagMappingList[].Tags | from_entries.\"tf-name\"",
      ".ResourceTagMappingList[].Tags[] | select(.Key  == \"tf-name\").Value"
    ],
    "utterance": "Extract the value associated with the key tf-name, which should yield tmp, from within each Tags list in the ResourceTagMappingList array.",
    "expressions": [
      ".ResourceTagMappingList[].Tags | from_entries.\"tf-name\"",
      ".ResourceTagMappingList[].Tags[] | select(.Key == \"tf-name\").Value"
    ],
    "data": [
      {
        "input": {
          "ResourceTagMappingList": [
            {
              "ResourceARN": "arn:aws:s3:::stack-hate-1234567890salt",
              "Tags": [
                {
                  "Key": "aws:cloudformation:stack-name",
                  "Value": "hatestack"
                },
                {
                  "Key": "aws:cloudformation:stack-id",
                  "Value": "arn:aws:cloudformation:us-west-2:6666666666666:stack/FSStack/hate-hate-hate-123456789"
                },
                {
                  "Key": "tf-name",
                  "Value": "tmp"
                },
                {
                  "Key": "aws:cloudformation:logical-id",
                  "Value": "hatebucket1234"
                },
                {
                  "Key": "aws-cdk:auto-delete-objects",
                  "Value": "true"
                }
              ]
            }
          ]
        },
        "output": "tmp"
      }
    ],
    "identifier": 72167446
  },
  {
    "context": [
      "the below json value of `name` is `demo` so, append an string to it like `-test` so the final value will be `demo-test`",
      "$ jq '.data.name |= . + \"-test\"' meta.json"
    ],
    "utterance": "Append -test to the value of the data.name field where its current value is demo.",
    "expressions": [
      ".data.name |= . + \"-test\""
    ],
    "data": [
      {
        "input": {
          "version": "2.2.0",
          "vname": "tf",
          "data": {
            "name": "demo",
            "udn": {
              "description": "The `main` tf in this template creates a resource`. "
            }
          }
        },
        "output": {
          "version": "2.2.0",
          "vname": "tf",
          "data": {
            "name": "demo-test",
            "udn": {
              "description": "The `main` tf in this template creates a resource`. "
            }
          }
        }
      }
    ],
    "identifier": 72187636
  },
  {
    "context": [
      "your `bash` \"for\" loop is suboptimal, in that a single jq invocation would be sufficient to produce the same result unless the glob expansion fails:",
      "    jq .sentence *.json",
      "If you have difficulties with this, then since you've indicated `ls *.json` works, the following should too:",
      "    cat *.json | jq .sentence",
      "For `argument list too long errors`, try this :",
      "find . -maxdepth 1 -mindepth 1 -name \"*.json\" -exec jq .sentence {} +",
      "`find` tries to append as many json files as possible in a single call to `jq`."
    ],
    "utterance": "Extract the value of the 'sentence' key from many files each containing an object with a 'sentence' key, as efficiently as possible.",
    "expressions": [
      "jq .sentence *.json",
      "cat *.json | jq .sentence",
      "find . -maxdepth 1 -mindepth 1 -name \"*.json\" -exec jq .sentence {} +"
    ],
    "identifier": 72187905
  },
  {
    "context": [
      "The desired outcome of this example would be 3 but in the future more models will be added.",
      "modelCount=\"$(jq '.variables.abc.models | length' $(Build.SourcesDirectory)/variables/templates/variables-sheet.jsonc)\"",
      "You can get the extract the count and store it in a shell variable with the following statement:",
      "modelCount=\"$(jq '.variables.abc.models | length' path/to/your/file\""
    ],
    "utterance": "Determine how many model objects are present under the variables.abc.models key.",
    "expressions": [
      ".variables.abc.models | length"
    ],
    "data": [
      {
        "input": {
          "variables": {
            "abc": {
              "models": {
                "model1": {
                  "a": "x",
                  "b": "z"
                },
                "model2": {
                  "a": "x",
                  "b": "z"
                },
                "model3": {
                  "a": "x",
                  "b": "z"
                }
              }
            }
          }
        },
        "output": 3
      }
    ],
    "identifier": 72189505
  },
  {
    "context": [
      "But the element should be only appended when the $bar is not an empty string, can I do something like this?",
      "You could just use `select` to filter out that case",
      "jq '[{values: (.foo + [.bar | select(. != \"\")]) | map({key:.})}]'"
    ],
    "utterance": "Append bar as an object with key property to the array values only if bar is not an empty string.",
    "expressions": [
      "[{values: (.foo + [.bar | select(. != \"\")]) | map({key:.})}]"
    ],
    "data": [
      {
        "input": {
          "foo": [
            "key1",
            "key2"
          ],
          "bar": "key3"
        },
        "output": [
          {
            "values": [
              {
                "key": "key1"
              },
              {
                "key": "key2"
              },
              {
                "key": "key3"
              }
            ]
          }
        ]
      },
      {
        "input": {
          "foo": [
            "key1",
            "key2"
          ],
          "bar": ""
        },
        "output": [
          {
            "values": [
              {
                "key": "key1"
              },
              {
                "key": "key2"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 72200061
  },
  {
    "context": [
      "But i would like to have the `\"x\":\"zero\"` be the first element of all array elements, not the last.",
      "In order for the new field to appear at the top, the object that holds it must appear first in the addition statement.",
      "$ jq  --argjson el \"$element\"  'map($el + .)'  <<<$example"
    ],
    "utterance": "Insert a field with key x and value zero as the first entry of each object in an array.",
    "expressions": [
      "map($el + .)"
    ],
    "data": [
      {
        "input": [
          {
            "a": "one",
            "b": "two",
            "c": "three"
          },
          {
            "d": "four",
            "e": "five",
            "f": "six"
          }
        ],
        "output": [
          {
            "x": "zero",
            "a": "one",
            "b": "two",
            "c": "three"
          },
          {
            "x": "zero",
            "d": "four",
            "e": "five",
            "f": "six"
          }
        ]
      }
    ],
    "identifier": 72204663
  },
  {
    "context": [
      "I want to select an element in the Users array that has SecurityName set to \"\" and change that element.",
      "Ultimately, selecting the SecurityName that was unset was done with:",
      "jq -r '.Users[] | select (.SecurityName == \"\") | {\"AuthProtocol\":.AuthProtocol,\"PrivacyProtocol\":.PrivacyProtocol,\"SecurityName\":.SecurityName,\"UserEngineID\":.UserEngineID}'"
    ],
    "utterance": "Select all elements in the Users array where SecurityName is an empty string.",
    "expressions": [
      ".Users[] | select(.SecurityName == \"\")",
      ".Users[] | select (.SecurityName == \"\") | {\"AuthProtocol\":.AuthProtocol,\"PrivacyProtocol\":.PrivacyProtocol,\"SecurityName\":.SecurityName,\"UserEngineID\":.UserEngineID}"
    ],
    "data": [
      {
        "input": {
          "Users": [
            {
              "AuthProtocol": "MD5",
              "PrivacyProtocol": "DES",
              "SecurityName": "",
              "UserEngineID": null
            },
            {
              "AuthProtocol": "SHA",
              "PrivacyProtocol": "AES",
              "SecurityName": "oneview_4849283d97929392",
              "UserEngineID": null
            }
          ]
        },
        "output": {
          "AuthProtocol": "MD5",
          "PrivacyProtocol": "DES",
          "SecurityName": "",
          "UserEngineID": null
        }
      }
    ],
    "identifier": 72199423
  },
  {
    "context": [
      "How can I (generically) transform the input file below to the output file below, using jq. The value at key \"id\" uniqely identifies the array element. The record format of the output file is: (value at key \"id\") | key | value.",
      "Input file:\n[{\"id\": 11, \"b\": 100},\n {\"id\": 12, \"d\": \"fred\", \"e\": 300}]",
      "Output File:\n11|id|11\n11|b|100\n12|id|12\n12|d|fred\n12|e|300",
      "jq -r '.[] | .id as $id | to_entries[] | [$id,.key,.value] | join(\"|\")'"
    ],
    "utterance": "Print each object's id, key, and value as lines formatted as id|key|value, using the 'id' value as the record identifier.",
    "expressions": [
      ".[] | .id as $id | to_entries[] | [$id,.key,.value] | join(\"|\")"
    ],
    "data": [
      {
        "input": [
          {
            "id": 11,
            "b": 100
          },
          {
            "id": 12,
            "d": "fred",
            "e": 300
          }
        ],
        "output": [
          "11|id|11",
          "11|b|100",
          "12|id|12",
          "12|d|fred",
          "12|e|300"
        ]
      }
    ],
    "identifier": 72200805
  },
  {
    "context": [
      "I want to avoid using JSON files and use variables but it doesn't work",
      "If I replace the filenames with $element and $example, it fails (expecting a file)",
      "jq --argjson el \"$element\" --argjson ex \"$example\" '$el += $ex'",
      "but it says jq: invalid JSON text passed to --argjson. I don't get it. The vars seem to be correct JSON.",
      "I just want this output, \"x\" first, using variables not files:",
      "{\n    \"x\": \"zero\",\n    \"a\": \"one\",\n    \"b\": \"two\",\n    \"c\": \"three\",\n}",
      "It worked using the comment suggestions like this",
      "jq -n --argjson el \"$element\" --argjson ex \"$example\" '$el + $ex'"
    ],
    "utterance": "Combine two objects stored in shell variables, with the first object's keys appearing before the second's in the result, without using files.",
    "expressions": [
      "jq -n --argjson el \"$element\" --argjson ex \"$example\" '$el + $ex'"
    ],
    "data": [
      {
        "input": {
          "element": "{\"x\":\"zero\"}",
          "example": "{\n    \"a\":\"one\",\n    \"b\":\"two\",\n    \"c\":\"three\"\n}"
        },
        "output": {
          "x": "zero",
          "a": "one",
          "b": "two",
          "c": "three"
        }
      }
    ],
    "identifier": 72203351
  },
  {
    "context": [
      "I am trying to extract the list of k8s deployment environment variables and merge the environment variables into a group of categories using jq and regex.",
      "I am looking for a slightly more elegant solution to my problem and, in addition, want to have the ability to manage a mapping of the categories with the relevant regex as additional input to the command.",
      "Here&#39;s one rewrite with several duplicates factored out. Decide for yourself if this meets your requirement for elegance:",
      "(\r\n  .metadata | {namespace, name}\r\n) + (\r\n  .spec.template.spec.containers[].env | {\r\n    databases: map(select(.name | contains (\"DB\"))),\r\n    redis: map(select(.name | contains (\"REDIS\"))),\r\n    elasticsearch: map(select(.name | test(\"^(ES_).\") or contains (\"ELASTIC\")))\r\n  }\r\n  | map_values(sort_by(.name))\r\n)",
      "Additionally, you could bring the sort up front to sort the unfiltered array just once:",
      "(\r\n  .metadata | {namespace, name}\r\n) + (\r\n  .spec.template.spec.containers[].env | sort_by(.name) | {\r\n    databases: map(select(.name | contains (\"DB\"))),\r\n    redis: map(select(.name | contains (\"REDIS\"))),\r\n    elasticsearch: map(select(.name | test(\"^(ES_).\") or contains (\"ELASTIC\")))\r\n  }\r\n)"
    ],
    "utterance": "Group environment variables from a deployment into categories: variables whose names contain 'DB' are under 'databases', those containing 'REDIS' under 'redis', and those matching /^ES_/ or containing 'ELASTIC' under 'elasticsearch', including namespace and name.",
    "expressions": [
      "(\n  .metadata | {namespace, name}\n) + (\n  .spec.template.spec.containers[].env | {\n    databases: map(select(.name | contains (\"DB\"))),\n    redis: map(select(.name | contains (\"REDIS\"))),\n    elasticsearch: map(select(.name | test(\"^(ES_).\") or contains (\"ELASTIC\")))\n  }\n  | map_values(sort_by(.name))\n)",
      "(\n  .metadata | {namespace, name}\n) + (\n  .spec.template.spec.containers[].env | sort_by(.name) | {\n    databases: map(select(.name | contains (\"DB\"))),\n    redis: map(select(.name | contains (\"REDIS\"))),\n    elasticsearch: map(select(.name | test(\"^(ES_).\") or contains (\"ELASTIC\")))\n  }\n)"
    ],
    "data": [
      {
        "input": {
          "apiVersion": "apps/v1",
          "kind": "Deployment",
          "metadata": {
            "labels": {
              "app": "test"
            },
            "name": "test"
          },
          "spec": {
            "replicas": 1,
            "selector": {
              "matchLabels": {
                "app": "test"
              }
            },
            "template": {
              "metadata": {
                "labels": {
                  "app": "test"
                }
              },
              "spec": {
                "containers": [
                  {
                    "name": "server",
                    "env": [
                      {
                        "name": "DB_MAINDB_HOST",
                        "value": "maindb.example.com"
                      },
                      {
                        "name": "DB_MAINDB_DATABASE",
                        "value": "test"
                      },
                      {
                        "name": "DB_MAINDB_USERNAME",
                        "value": "username"
                      },
                      {
                        "name": "DB_MAINDB_PASSWORD",
                        "value": "password"
                      },
                      {
                        "name": "ES_HOST",
                        "value": "es-client.example.com"
                      },
                      {
                        "name": "ES_INDEX",
                        "value": "test"
                      },
                      {
                        "name": "REDIS_HOST",
                        "value": "redis.example.com"
                      }
                    ],
                    "image": "bustbox"
                  }
                ]
              }
            }
          }
        },
        "output": {
          "namespace": "default",
          "name": "test",
          "databases": [
            {
              "name": "DB_MAINDB_DATABASE",
              "value": "test"
            },
            {
              "name": "DB_MAINDB_HOST",
              "value": "maindb.example.com"
            },
            {
              "name": "DB_MAINDB_PASSWORD",
              "value": "password"
            },
            {
              "name": "DB_MAINDB_USERNAME",
              "value": "username"
            }
          ],
          "redis": [
            {
              "name": "REDIS_HOST",
              "value": "redis.example.com"
            }
          ],
          "elasticsearch": [
            {
              "name": "ES_HOST",
              "value": "es-client.example.com"
            },
            {
              "name": "ES_INDEX",
              "value": "test"
            }
          ]
        }
      }
    ],
    "identifier": 72174860
  },
  {
    "context": [
      "I need to find the ID of each and every Passed tasks (\"state\": \"Passed\") using a bash script.",
      "jq -r '.tasks | .[] | select (.state == \"Passed\") | .id' file.json"
    ],
    "utterance": "Find the id of all tasks with state equal to Passed.",
    "expressions": [
      ".tasks | .[] | select(.state == \"Passed\") | .id"
    ],
    "data": [
      {
        "input": {
          "tasks": [
            {
              "id": "nightly_1652299200",
              "repo": "tx/tx5",
              "branch": "dev",
              "type": "HealthCheck",
              "started_on": "2022-05-11 23:00:00 +0300 EEST",
              "state": "Running",
              "top_sha": "10143120c12cd506fca5a466a7c6b27e7cb35b18",
              "tested_shas": null,
              "self_url": "tx/tx5/10143120c12cd506fca5a466a7c6b27e7cb35b18",
              "is_public": true
            },
            {
              "id": "1652298808",
              "repo": "tx/tx3d",
              "branch": "6.3",
              "type": "Integration",
              "started_on": "2022-05-11 22:53:28 +0300 EEST",
              "state": "Passed",
              "top_sha": "40ca8db14a8ddd082270a81e895bf01048949ec4",
              "tested_shas": null,
              "self_url": "tx/tx3d/40ca8db14a8ddd082270a81e895bf01048949ec4",
              "is_public": true
            },
            {
              "id": "1652298252",
              "repo": "tx/qtmultimedia",
              "branch": "dev",
              "type": "Integration",
              "started_on": "2022-05-11 22:44:12 +0300 EEST",
              "state": "Failed",
              "top_sha": "d7dd593b6395a33862742a04a23d88b970f7b914",
              "tested_shas": null,
              "self_url": "qt/qtmultimedia/d7dd593b6395a33862742a04a23d88b970f7b914",
              "is_public": true
            }
          ]
        },
        "output": [
          "1652298808"
        ]
      }
    ],
    "identifier": 72207300
  },
  {
    "context": [
      "var1='[\n{\"a\":\"1\",\"b\":\"2\",\"c\":\"3\"},\n{\"a\":\"4\",\"b\":\"5\",\"c\":\"6\"},\n{\"a\":\"7\",\"b\":\"8\",\"c\":\"9\"}\n]'",
      "var2='[\n{\"d\":\"x\",\"e\":\"y\"},\n{\"d\":\"z\",\"e\":\"q\"},\n{\"d\":\"w\",\"e\":\"v\"}\n]'",
      "The result I want is\n'[\n{\"a\":\"1\",\"b\":\"2\",\"c\":\"3\",\"d\":\"x\",\"e\":\"y\"},\n{\"a\":\"4\",\"b\":\"5\",\"c\":\"6\",\"d\":\"z\",\"e\":\"q\"},\n{\"a\":\"7\",\"b\":\"8\",\"c\":\"9\",\"d\":\"w\",\"e\":\"v\"}\n]'",
      "jq -n --argjson var1 \"$var1\" --argjson var2 \"$var2\" '$var1 + $var2'",
      "Use `transpose` to align the elements from both input arrays, then `add` to combine both sides:",
      "jq -n --argjson var1 \"$var1\" --argjson var2 \"$var2\" '\n  [$var1, $var2] | [transpose[] | add]\n'"
    ],
    "utterance": "Combine two array variables of equal length elementwise by merging corresponding objects from each array into a single array of merged objects.",
    "expressions": [
      "[$var1, $var2] | [transpose[] | add]"
    ],
    "data": [
      {
        "input": [
          [
            {
              "a": "1",
              "b": "2",
              "c": "3"
            },
            {
              "a": "4",
              "b": "5",
              "c": "6"
            },
            {
              "a": "7",
              "b": "8",
              "c": "9"
            }
          ],
          [
            {
              "d": "x",
              "e": "y"
            },
            {
              "d": "z",
              "e": "q"
            },
            {
              "d": "w",
              "e": "v"
            }
          ]
        ],
        "output": [
          {
            "a": "1",
            "b": "2",
            "c": "3",
            "d": "x",
            "e": "y"
          },
          {
            "a": "4",
            "b": "5",
            "c": "6",
            "d": "z",
            "e": "q"
          },
          {
            "a": "7",
            "b": "8",
            "c": "9",
            "d": "w",
            "e": "v"
          }
        ]
      }
    ],
    "identifier": 72207971
  },
  {
    "context": [
      "How to construct a name of a variable from data and access that variable?",
      "For example it should somehow give the content of the alpha-file:",
      "It should output:\n[\n  0\n]",
      "So there is a dictionary to extract variables by a string name from:\n\n```\njq '$ARGS.named[\"\\(.var)-file\"]' --slurpfile alpha-file <(echo 0) --slurpfile beta-file <(echo 1) <<<'{\"var\": \"alpha\"}'\n```",
      "You could use `getpath` like this:\n```\njq --slurpfile alphaFile <(echo 0) --slurpfile betaFile <(echo 1) '\n   .var as $ab | {alpha: $alphaFile, beta: $betaFile} | getpath([$ab])' <<<'{\"var\": \"alpha\"}'\n```\n\nBetter yet:\n\n```\njq --slurpfile alpha <(echo 0) --slurpfile beta <(echo 1) '\n   .var as $ab | {$alpha, $beta} | getpath([$ab])' <<<'{\"var\": \"alpha\"}'\n```"
    ],
    "utterance": "Retrieve the content of a variable whose name is dynamically constructed by combining a data value with a suffix, such as accessing the file named by '.var + \"-file\"' where .var is \"alpha\".",
    "expressions": [
      "$ARGS.named[\"\\(.var)-file\"]",
      ".var as $ab | {alpha: $alphaFile, beta: $betaFile} | getpath([$ab])",
      ".var as $ab | {$alpha, $beta} | getpath([$ab])"
    ],
    "data": [
      {
        "input": {
          "var": "alpha"
        },
        "output": [
          0
        ]
      }
    ],
    "identifier": 72212751
  },
  {
    "context": [
      "I have been able to export the data successfully to TSV already, but it reads per-line, and without preserving order, like so:\n\n*Using `jq -r '.ticket_fields[] | select(.type==\"tagger\") | [.id, .custom_field_options[].name, .custom_field_options[].value] | @tsv'*`*\n\n| Ticket Field ID | Name | Name | Value | Value |\n| -------- | -------------- | ------- | ------- |------- |\n| 1122334455| I have a problem | I have feedback | help_i_have_problem| help_i_have_feedback|\n| 6677889900| United States | Germany | location_123_united_states| location_456_germany|\n\nEach of the `custom_field_options` arrays in production may consist of any number of objects (not limited to 2 each). But I seem to be stuck on how to appropriately group or map these objects to their parent `ticket_fields.id` and to transpose the data in a clean manner. The `select(.type==\"tagger\")` is mentioned in the query as there are multiple values for `ticket_fields.type` which need to be filtered out.",
      "You need two nested iterations, one in each array. Save the value of `.id` in a variable to access it later.\n~~~sh\njq -r '\n  .ticket_fields[] | select(.type==\"tagger\") | .id as $id\n  | .custom_field_options[] | [$id, .name, .value]\n  | @tsv\n'\n~~~"
    ],
    "utterance": "List each entry from every custom_field_options array, together with its parent ticket_fields.id, including only those where type equals tagger, presenting each record as a line with id, name, and value fields.",
    "expressions": [
      ".ticket_fields[] | select(.type==\"tagger\") | .id as $id | .custom_field_options[] | [$id, .name, .value] | @tsv"
    ],
    "data": [
      {
        "input": {
          "ticket_fields": [
            {
              "url": "https://example.com/1122334455.json",
              "id": 1122334455,
              "type": "tagger",
              "custom_field_options": [
                {
                  "id": 123456789,
                  "name": "I have a problem",
                  "raw_name": "I have a problem",
                  "value": "help_i_have_problem",
                  "default": false
                },
                {
                  "id": 456789123,
                  "name": "I have feedback",
                  "raw_name": "I have feedback",
                  "value": "help_i_have_feedback",
                  "default": false
                }
              ]
            },
            {
              "url": "https://example.com/6677889900.json",
              "id": 6677889900,
              "type": "tagger",
              "custom_field_options": [
                {
                  "id": 321654987,
                  "name": "United States",
                  "raw_name": "United States",
                  "value": "location_123_united_states",
                  "default": false
                },
                {
                  "id": 987456321,
                  "name": "Germany",
                  "raw_name": "Germany",
                  "value": "location_456_germany",
                  "default": false
                }
              ]
            }
          ]
        },
        "output": "1122334455\tI have a problem\thelp_i_have_problem\n1122334455\tI have feedback\thelp_i_have_feedback\n6677889900\tUnited States\tlocation_123_united_states\n6677889900\tGermany\tlocation_456_germany"
      }
    ],
    "identifier": 72205843
  },
  {
    "context": [
      "Now I would like to merge the dataset in a way so that I have grouped `session` ID's to `src_ip` at one place such as",
      "With `group_by` you can group by any criteria given, then assemble all grouped items by taking their common `.src_ip` from any of them (eg. the first), and `.sessions` as a mapped array on `.session` from all of them.",
      "jq 'group_by(.src_ip) | map({src_ip: .[0].src_ip, sessions: map(.session)})'"
    ],
    "utterance": "Group all session IDs into an array for each distinct src_ip, producing objects with src_ip and sessions fields.",
    "expressions": [
      "group_by(.src_ip) | map({src_ip: .[0].src_ip, sessions: map(.session)})"
    ],
    "data": [
      {
        "input": [
          {
            "session": "ffe887f3f150",
            "src_ip": "81.71.87.156"
          },
          {
            "session": "fff42102e329",
            "src_ip": "143.198.224.52"
          },
          {
            "session": "fff9c8ca82be",
            "src_ip": "159.203.97.7"
          },
          {
            "session": "abc123456789",
            "src_ip": "81.71.87.156"
          }
        ],
        "output": [
          {
            "src_ip": "143.198.224.52",
            "sessions": [
              "fff42102e329"
            ]
          },
          {
            "src_ip": "159.203.97.7",
            "sessions": [
              "fff9c8ca82be"
            ]
          },
          {
            "src_ip": "81.71.87.156",
            "sessions": [
              "ffe887f3f150",
              "abc123456789"
            ]
          }
        ]
      }
    ],
    "identifier": 72217255
  },
  {
    "context": [
      "in this I want to find value `wft-sn` and append an suffix `-test` to it",
      "so the updated json file should look like this",
      "`jq '. | select(.spec.templates[].dag.tasks[].templateRef.name == \"wft-sn\").name |= . + \"-test\"' demo.json`",
      "\"jq '(.spec.templates[].dag.tasks[].templateRef.name | select(. == \"wft-sn\")) += \"-test\"'\"",
      "I have also removed the unnecessary `. |` and reduced `|= . +` to `+=`."
    ],
    "utterance": "Append the suffix '-test' to each templateRef.name value that is exactly 'wft-sn'.",
    "expressions": [
      "(.spec.templates[].dag.tasks[].templateRef.name | select(. == \"wft-sn\")) += \"-test\""
    ],
    "data": [
      {
        "input": {
          "apiVersion": "argoproj.io/v1alpha1",
          "kind": "Workflow",
          "metadata": {
            "generateName": "kns-vm-"
          },
          "spec": {
            "templates": [
              {
                "inputs": {
                  "parameters": [
                    {
                      "name": "un",
                      "value": "org"
                    }
                  ]
                },
                "dag": {
                  "tasks": [
                    {
                      "name": "create-ns",
                      "templateRef": {
                        "name": "wft-kn"
                      },
                      "arguments": {
                        "parameters": [
                          {
                            "name": "un",
                            "value": "{{inputs.parameters.un}}"
                          }
                        ]
                      }
                    },
                    {
                      "name": "create-sm",
                      "templateRef": {
                        "name": "wft-sn"
                      },
                      "arguments": {
                        "parameters": [
                          {
                            "name": "un",
                            "value": "{{inputs.parameters.un}}"
                          }
                        ]
                      }
                    }
                  ]
                }
              }
            ]
          }
        },
        "output": {
          "apiVersion": "argoproj.io/v1alpha1",
          "kind": "Workflow",
          "metadata": {
            "generateName": "kns-vm-"
          },
          "spec": {
            "templates": [
              {
                "inputs": {
                  "parameters": [
                    {
                      "name": "un",
                      "value": "org"
                    }
                  ]
                },
                "dag": {
                  "tasks": [
                    {
                      "name": "create-ns",
                      "templateRef": {
                        "name": "wft-kn"
                      },
                      "arguments": {
                        "parameters": [
                          {
                            "name": "un",
                            "value": "{{inputs.parameters.un}}"
                          }
                        ]
                      }
                    },
                    {
                      "name": "create-sm",
                      "templateRef": {
                        "name": "wft-sn-test"
                      },
                      "arguments": {
                        "parameters": [
                          {
                            "name": "un",
                            "value": "{{inputs.parameters.un}}"
                          }
                        ]
                      }
                    }
                  ]
                }
              }
            ]
          }
        }
      }
    ],
    "identifier": 72215572
  },
  {
    "context": [
      "I want to recreate this in a shell script where \"names\" come from a shell array",
      "but I run into \n```\njq: error: $ITER is not defined at <top-level>, line 1:\n.input.names[$ITER] += $val             \njq: 1 compile error\n```",
      "You could get rid of the shell loop and use one `jq` call:\n\n```bash\nnames=( alice bob )\njq -n --arg names \"${names[*]}\" '{\"input\": {\"names\": ($names / \" \") } }'\n```",
      "or\n```bash\nnames=( alice bob )\nprintf '%s\\0' \"${names[@]}\" |\njq -sR '(. / \"\\u0000\") as $names | { \"input\": { \"names\": $names } }'\n```",
      "Here\u2019s a `bash` solution which captures the output using `$(...)` and provides it for the next using `<<<`. (Note that there are better ways to solve this problem, e.g. without looping but by providing `jq` all elements to be added at once.)",
      "json='{ \"input\": { \"names\":[] } }'\nfor i in alice bob\ndo json=\"$(jq --arg val \"$i\" '.input.names += [$val]' <<< \"$json\")\"\ndone\necho \"$json\""
    ],
    "utterance": "Produce an object with a 'names' array containing all values from a shell array.",
    "expressions": [
      "{ \"input\": { \"names\": ($names / \" \") } }",
      "(. / \"\\u0000\") as $names | { \"input\": { \"names\": $names } }",
      ".input.names += [$val]"
    ],
    "data": [
      {
        "input": {
          "names": [
            "alice",
            "bob"
          ]
        },
        "output": {
          "input": {
            "names": [
              "alice",
              "bob"
            ]
          }
        }
      }
    ],
    "identifier": 72215851
  },
  {
    "context": [
      "I want to get the ID where the name is - terraform-02",
      "you can select the .id like this:",
      "jq '.[][] | select(.name? == \"terraform-02\").id'",
      "The output is:",
      "\"id1\"",
      "\"id2\""
    ],
    "utterance": "Extract all id values where name equals terraform-02 in the ssh_keys array.",
    "expressions": [
      ".[][] | select(.name? == \"terraform-02\").id"
    ],
    "data": [
      {
        "input": {
          "ssh_keys": [
            {
              "id": "id1",
              "public_key": "pk1",
              "name": "terraform-02",
              "fingerprint": "..."
            },
            {
              "id": "id2",
              "public_key": "pk2",
              "name": "terraform-02",
              "fingerprint": "..."
            }
          ],
          "meta": {
            "total": 2
          }
        },
        "output": [
          "id1",
          "id2"
        ]
      }
    ],
    "identifier": 72228730
  },
  {
    "context": [
      "Assuming I have the following JSON object _(which is just an example):_\n\n```\n{ \n  \"foo\": 1, \n  \"bar\": 2, \n  \"baz\": 3 \n}\n```\n\nAnd the following JSON array _(another example):_\n\n```\n[\"foo\", \"baz\"]\n```\n\nHow could I use [**jq**](https://stedolan.github.io/jq) to output the following object?\n\n```\n{ \n  \"foo\": 1, \n  \"baz\": 3 \n}\n```",
      "Using a `reduce` to iteratively build up the result object would be one way:\n~~~sh\necho '[\"foo\", \"baz\"]' | jq --argjson index '{\"foo\":1,\"bar\":2,\"baz\":3}' '\n  reduce .[] as $x ({}; .[$x] = $index[$x])\n'\n~~~",
      "Using `JOIN`, creating key-value pairs, and employing `from_entries` for assembly would be another way:\n~~~sh\necho '[\"baz\", \"foo\"]' | jq --argjson index '{\"foo\":1,\"bar\":2,\"baz\":3}' '\n  JOIN($index; .) | map({key:.[0], value:.[1]}) | from_entries\n'\n~~~",
      "Provided that `.` is the object and `$arr` is the array, the following does the trick\n```\ndelpaths(keys - $arr | map([.]))\n```",
      "Here's a reduce-free solution that assumes $keys is the array of keys of interest and that is possibly more efficient than the one involving array subtraction:\n\n    . as $in | INDEX( $keys[]; $in[.] )\n"
    ],
    "utterance": "Select only specified properties from an object given an array of property names, omitting the rest.",
    "expressions": [
      "reduce $arr[] as $x ({}; .[$x] = .[$x])",
      "JOIN(.; $arr) | map({key:.[0], value:.[1]}) | from_entries",
      "delpaths(keys - $arr | map([.]))",
      ". as $in | INDEX($arr[]; $in[.])"
    ],
    "data": [
      {
        "input": {
          "object": {
            "foo": 1,
            "bar": 2,
            "baz": 3
          },
          "array": [
            "foo",
            "baz"
          ]
        },
        "output": {
          "foo": 1,
          "baz": 3
        }
      }
    ],
    "identifier": 72218950
  },
  {
    "context": [
      "Is there a way to have the format in `myPath` accept the wildcard as an object in the passed `$str` path?",
      "Don't think there is a way to let `getPath` deal with filters like\n`.[].alpha.hello`",
      "However, you can use the `myPath` variable as the *raw* filter itself to get the desired output:\n```\n$ myPath=\".[].alpha.hello\"\n$ jq -r --arg str \"${myPath}\" \"$myPath\" json.json\nworld\n```",
      "You could use \n\n```jq\ndef _simple_query( $q ):\n   if $q | length == 0 then\n      .\n   else\n      $q[0] as $key |\n      $q[1:] as $r |\n      if $key == \"*\" then\n         .[] | _simple_query( $r )\n      else\n         select( has( $key ) ) | .[ $key ] | _simple_query( $r )\n      end\n   end;\n\ndef simple_query( $q ):\n   _simple_query( $q | split(\".\"));\n\nsimple_query( \"*.alpha.hello\" )\n```"
    ],
    "utterance": "Retrieve the value at the path where a wildcard is used at the object level, specifically extracting 'hello' from any top-level child, such as '*.alpha.hello'.",
    "expressions": [
      "def _simple_query( $q ): if $q | length == 0 then . else $q[0] as $key | $q[1:] as $r | if $key == \"*\" then .[] | _simple_query( $r ) else select( has( $key ) ) | .[ $key ] | _simple_query( $r ) end end; def simple_query( $q ): _simple_query( $q | split(\".\")); simple_query( \"*.alpha.hello\" )"
    ],
    "data": [
      {
        "input": {
          "notKnown": {
            "alpha": {
              "hello": "world"
            }
          }
        },
        "output": "world"
      }
    ],
    "identifier": 72228178
  },
  {
    "context": [
      "Your document format is json, so you should use jq for editing:",
      "jq '.files[0].aql.\"items.find\".\"$or\"[0].\"$and\"[0].name.\"$nmatch\"=\"build1.1\"' spec",
      "A more \"indirect\" way is to simply set everything with `$nmatch`:",
      "jq '(.. | select(has(\"$nmatch\"))? ) = \"build1.1\"' input.json"
    ],
    "utterance": "Set the value of all \"$nmatch\" keys to \"build1.1\", or specifically update the key at .files[0].aql.\"items.find\".\"$or\"[0].\"$and\"[0].name.\"$nmatch\" to \"build1.1\".",
    "expressions": [
      ".files[0].aql.\"items.find\".\"$or\"[0].\"$and\"[0].name.\"$nmatch\" = \"build1.1\"",
      "(.. | select(has(\"$nmatch\"))? ) = \"build1.1\""
    ],
    "data": [
      {
        "input": {
          "files": [
            {
              "aql": {
                "items.find": {
                  "repo": {
                    "$eq": "app-java-repo"
                  },
                  "path": "archives/test/app",
                  "type": "folder",
                  "$or": [
                    {
                      "$and": [
                        {
                          "name": {
                            "$nmatch": "*build*"
                          }
                        }
                      ]
                    }
                  ]
                }
              }
            }
          ]
        },
        "output": {
          "files": [
            {
              "aql": {
                "items.find": {
                  "repo": {
                    "$eq": "app-java-repo"
                  },
                  "path": "archives/test/app",
                  "type": "folder",
                  "$or": [
                    {
                      "$and": [
                        {
                          "name": {
                            "$nmatch": "build1.1"
                          }
                        }
                      ]
                    }
                  ]
                }
              }
            }
          ]
        }
      }
    ],
    "identifier": 72256635
  },
  {
    "context": [
      "I am trying to get the output in the following format, i.e. with null:",
      "[\n  {\n    \"ID\": 6,\n    \"Title\": \"ABC\",\n    \"like\": null\n  },\n  {\n    \"ID\": 22,\n    \"Title\": \"ABC\",\n    \"like\": \"Yes\"\n  }\n]",
      "If you want to have a JSON string in the regular case, and `null` in the case where it is empty, import the content of `${like}` as string using `--arg` ... then use some jq logic to turn the empty string into null. An if statement would do, for example:",
      "jq -n --arg like \"${like}\" '{like: (if $like == \"\" then null else $like end)}'"
    ],
    "utterance": "Produce objects where the 'like' property is null if it is an empty string, otherwise preserve its value.",
    "expressions": [
      "{like: (if $like == \"\" then null else $like end)}"
    ],
    "data": [
      {
        "input": [
          {
            "ID": 6,
            "Title": "ABC",
            "like": ""
          },
          {
            "ID": 22,
            "Title": "ABC",
            "like": "Yes"
          }
        ],
        "output": [
          {
            "ID": 6,
            "Title": "ABC",
            "like": null
          },
          {
            "ID": 22,
            "Title": "ABC",
            "like": "Yes"
          }
        ]
      }
    ],
    "identifier": 72265338
  },
  {
    "context": [
      "Does `jq` support case insensitive sorting?",
      "actually `jq` has built-in filters `ascii_downcase` and `ascii_upcase` you can use like this `jq 'sort_by(.title | ascii_downcase)' data.json` to get proper result."
    ],
    "utterance": "Sort an array of objects by the 'title' field in case-insensitive order.",
    "expressions": [
      "sort_by(.title | ascii_downcase)"
    ],
    "data": [
      {
        "input": [
          {
            "title": "first",
            "description": "foo"
          },
          {
            "title": "Second",
            "description": "bar"
          }
        ],
        "output": [
          {
            "title": "first",
            "description": "foo"
          },
          {
            "title": "Second",
            "description": "bar"
          }
        ]
      }
    ],
    "identifier": 72277908
  },
  {
    "context": [
      "I need output like below. It could be possible that Subject tag is missing so that record should be skipped.",
      "Amit,Maths,10",
      "Amit,Science,20",
      "jq -r '\n  .name as $name | .Subject? // empty | keys_unsorted[] as $key\n  | [$name, $key, .[$key].Score] | join(\",\")\n'"
    ],
    "utterance": "For each subject, output the person's name, subject name, and score as a comma-separated line, skipping records if the subject field is missing.",
    "expressions": [
      ".name as $name | .Subject? // empty | keys_unsorted[] as $key | [$name, $key, .[$key].Score] | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "name": "Amit",
          "Subject": {
            "Maths": {
              "Score": 10,
              "ttl": 480
            },
            "Science": {
              "Score": 20,
              "ttl": 480
            }
          }
        },
        "output": [
          "Amit,Maths,10",
          "Amit,Science,20"
        ]
      }
    ],
    "identifier": 72291224
  },
  {
    "context": [
      "What I'm trying to do currently, is, within each environment, compare mainAccount and secondAccount values.",
      "Meaning, in testing environment, I want to check if mainAccount = secondAccount, and same in production environment.",
      "I simply want to, for each .json file above, compare the mainAccount and secondAccount values with eachother, within each environment.",
      "Given your input you can try this `jq`:\n\n```\njq '\n    .config[]\n    | {\n        environment,\n        condition: (.main[0].mainAccount == .second[0].secondAccount)\n    }' input.json\n```",
      "The result is:\n```json\n{\n  \"environment\": \"testing\",\n  \"condition\": false\n}\n{\n  \"environment\": \"production\",\n  \"condition\": true\n}\n```",
      "Also: If you want to process the results in a shell, I propose this expression because the output can be used (`source` or `eval`) in a shell:\n\n```\njq -r '\n    .config[]\n    | \"\\(.environment)=\\(.main[0].mainAccount == .second[0].secondAccount)\"' input.json\n```\n\nThe output is:\n\n    testing=false\n    production=true"
    ],
    "utterance": "Check for each environment if mainAccount equals secondAccount, returning the environment and whether they are equal.",
    "expressions": [
      ".config[] | {environment, condition: (.main[0].mainAccount == .second[0].secondAccount)}",
      ".config[] | \"\\(.environment)=\\(.main[0].mainAccount == .second[0].secondAccount)\""
    ],
    "data": [
      {
        "input": {
          "file_version": 1.0,
          "config": [
            {
              "environment": "testing",
              "main": [
                {
                  "mainAccount": "123"
                }
              ],
              "second": [
                {
                  "secondAccount": "456"
                }
              ]
            },
            {
              "environment": "production",
              "main": [
                {
                  "mainAccount": "789"
                }
              ],
              "second": [
                {
                  "secondAccount": "789"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "environment": "testing",
            "condition": false
          },
          {
            "environment": "production",
            "condition": true
          }
        ]
      }
    ],
    "identifier": 72277613
  },
  {
    "context": [
      "I have the following json",
      "And I want the following output",
      "Use a `map` to retain the array while modifying (here: reducing) it to your needs:",
      "jq '.data[] | {id, arr: .arr | map({arrId})}'"
    ],
    "utterance": "Output each object with its id and an arr field containing only objects with arrId.",
    "expressions": [
      ".data[] | {id, arr: .arr | map({arrId})}"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": "id1",
              "arr": [
                {
                  "arrId": "arrId11",
                  "someOtherKey1": "xxx",
                  "someOtherKey2": "xxx"
                },
                {
                  "arrId": "arrId12",
                  "someOtherKey1": "xxx",
                  "someOtherKey2": "xxx"
                }
              ],
              "otherParentLevelKey": "yyyyy"
            },
            {
              "id": "id2",
              "arr": [
                {
                  "arrId": "arrId21",
                  "someOtherKey1": "xxx",
                  "someOtherKey2": "xxx"
                },
                {
                  "arrId": "arrId22",
                  "someOtherKey1": "xxx",
                  "someOtherKey2": "xxx"
                }
              ],
              "otherParentLevelKey": "yyyyy"
            }
          ]
        },
        "output": [
          {
            "id": "id1",
            "arr": [
              {
                "arrId": "arrId11"
              },
              {
                "arrId": "arrId12"
              }
            ]
          },
          {
            "id": "id2",
            "arr": [
              {
                "arrId": "arrId21"
              },
              {
                "arrId": "arrId22"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 72284649
  },
  {
    "context": [
      "I need to generate a list of every \"item\" in the JSON where \"product\" contains \"bitbucket\" (for example).",
      "jq -r '.items[] | select(.product | contains([\"bitbucket\"]))? | .cidr'",
      "This worked perfectly"
    ],
    "utterance": "List all 'cidr' values from each 'item' where the 'product' array contains 'bitbucket'.",
    "expressions": [
      ".items[] | select(.product | contains([\"bitbucket\"]))? | .cidr",
      "map(select(.product | contains([\"bitbucket\"]))) | .[] | .cidr"
    ],
    "data": [
      {
        "input": {
          "syncToken": 1644822802,
          "creationDate": "2022-02-14T07:13:22.789203",
          "items": [
            {
              "direction": [
                "ingress",
                "egress"
              ],
              "network": "3.26.128.128",
              "mask_len": 26,
              "region": [
                "ap-southeast-2"
              ],
              "mask": "255.255.255.192",
              "product": [
                "confluence",
                "jira",
                "bitbucket",
                "opsgenie",
                "statuspage",
                "halp",
                "trello"
              ],
              "cidr": "3.26.128.128/26"
            },
            {
              "direction": [
                "ingress"
              ],
              "network": "3.27.0.0",
              "mask_len": 24,
              "region": [
                "ap-southeast-2"
              ],
              "mask": "255.255.255.0",
              "product": [
                "confluence"
              ],
              "cidr": "3.27.0.0/24"
            }
          ]
        },
        "output": [
          "3.26.128.128/26"
        ]
      }
    ],
    "identifier": 72294351
  },
  {
    "context": [
      "Objectives:\n`name` renamed to `pathParameterName`\n`type` renamed to `datasetParameter`",
      "Raw Json I'm trying to convert",
      "Json desired outcome:",
      "The function `to_entries`, \"converts between an object and an array of key-value pairs\" (see the [manual](https://stedolan.github.io/jq/manual/#to_entries,from_entries,with_entries)). To rename the preset `key` and `value` fields, just reassign them to a new name with a new object as in `{valueReference: .key, value}`.",
      "jq '\n  .pathOptions.parameters |= (\n    to_entries | map({\n      pathParameterName: .key,\n      datasetParameter: (\n        .value | .filter.valuesMap |= (\n          to_entries | map({valueReference: .key, value})\n        )\n      )\n    })\n  )\n'",
      "{\n  \"pathOptions\": {\n    \"parameters\": [\n      {\n        \"pathParameterName\": \"raw_date\",\n        \"datasetParameter\": {\n          \"name\": \"raw_date\",\n          \"type\": \"Datetime\",\n          \"datetimeOptions\": {\n            \"localeCode\": \"en-GB\"\n          },\n          \"createColumn\": true,\n          \"filter\": {\n            \"expression\": \"(after :date1)\",\n            \"valuesMap\": [\n              {\n                \"valueReference\": \":date1\",\n                \"value\": \"2022-03-08T00:00:00.000Z\"\n              }\n            ]\n          }\n        }\n      }\n    ]\n  }\n}"
    ],
    "utterance": "Transform an object so that inside pathOptions.parameters, each key is mapped to an object with key pathParameterName (the original key) and key datasetParameter (the original value), and inside datasetParameter.filter.valuesMap, convert each key-value pair into an object with keys valueReference and value.",
    "expressions": [
      ".pathOptions.parameters |= ( to_entries | map({ pathParameterName: .key, datasetParameter: ( .value | .filter.valuesMap |= ( to_entries | map({valueReference: .key, value}) ) ) }) )"
    ],
    "data": [
      {
        "input": {
          "pathOptions": {
            "parameters": {
              "raw_date": {
                "name": "raw_date",
                "type": "Datetime",
                "datetimeOptions": {
                  "localeCode": "en-GB"
                },
                "createColumn": true,
                "filter": {
                  "expression": "(after :date1)",
                  "valuesMap": {
                    ":date1": "2022-03-08T00:00:00.000Z"
                  }
                }
              }
            }
          }
        },
        "output": {
          "pathOptions": {
            "parameters": [
              {
                "pathParameterName": "raw_date",
                "datasetParameter": {
                  "name": "raw_date",
                  "type": "Datetime",
                  "datetimeOptions": {
                    "localeCode": "en-GB"
                  },
                  "createColumn": true,
                  "filter": {
                    "expression": "(after :date1)",
                    "valuesMap": [
                      {
                        "valueReference": ":date1",
                        "value": "2022-03-08T00:00:00.000Z"
                      }
                    ]
                  }
                }
              }
            ]
          }
        }
      }
    ],
    "identifier": 72291596
  },
  {
    "context": [
      "I would like to parse data from a JSON-file into a tsv-file, but I cannot make it work.",
      "The desired output is a tab-separated table\n\n    ubuntu    latest\n    debian    latest\n    debian    10.0",
      "Save the name into a variable before you go down to the tags",
      "jq -r '.images[] | .name as $name | .tags[] | [$name, .] | @tsv'"
    ],
    "utterance": "Extract each image's name paired with each of its tags as tab-separated values.",
    "expressions": [
      ".images[] | .name as $name | .tags[] | [$name, .] | @tsv"
    ],
    "data": [
      {
        "input": {
          "images": [
            {
              "id": "592a77a5-614e-4ed8-b846-d4db1f27edbf",
              "name": "ubuntu",
              "tags": [
                "latest"
              ]
            },
            {
              "id": "592da7a5-614e-4ed8-b846-d4db1f27edbf",
              "name": "debian",
              "tags": [
                "latest",
                "10.0"
              ]
            }
          ]
        },
        "output": "ubuntu\tlatest\ndebian\tlatest\ndebian\t10.0\n"
      }
    ],
    "identifier": 72300979
  },
  {
    "context": [
      "\"I want to echo 1 string for every object in the array, so that the string text displays the headline, and the string is clickable to the url.\"",
      "\"echo -e \\\"\\e]8;;$URL\\a$TITLE\\e]8;;\\a\\\"\"",
      "\"echo \"$results\" | jq -r '.results[] | \"\\u001b]8;;\\(.url)\\u0007\\(.title)\\u001b]8;;\\u0007\"'\"",
      "\"jq -r $'.results[] | \"\\e]8;;\\(.url)\\a\\(.title)\\e]8;;\\a\"' <<< \"$results\"\""
    ],
    "utterance": "Output, for each array item, a clickable string formatted with control sequences so the text displays the headline and links to its URL.",
    "expressions": [
      ".results[] | \"\\u001b]8;;\\(.url)\\u0007\\(.title)\\u001b]8;;\\u0007\"",
      "$'.results[] | \"\\e]8;;\\(.url)\\a\\(.title)\\e]8;;\\a\"'"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "headline": "such and such",
              "url": "http://such.and.such.com"
            },
            {
              "headline": "so and so",
              "url": "http://so.and.so.com"
            }
          ]
        },
        "output": [
          "\u001b]8;;http://such.and.such.com\u0007such and such\u001b]8;;\u0007",
          "\u001b]8;;http://so.and.so.com\u0007so and so\u001b]8;;\u0007"
        ]
      }
    ],
    "identifier": 72297298
  },
  {
    "context": [
      "I want to go from\n\n[\n  {\"key_skjdghkbs\": \"deep house\"},\n  {\"key_kjsskjbgs\": \"deadmau5\"},\n  {\"key_jhw98w4hl\": \"progressive house\"},\n  {\"key_sjkh348vg\": \"swedish house mafia\"},\n  {\"key_js3485jwh\": \"dubstep\"},\n  {\"key_jsg587jhs\": \"escape\"}\n]\n\nto \n\n{\n  \"key_skjdghkbs\": \"deep house\",\n  \"key_kjsskjbgs\": \"deadmau5\"\n  \"key_jhw98w4hl\": \"progressive house\",\n  \"key_sjkh348vg\": \"swedish house mafia\",\n  \"key_js3485jwh\": \"dubstep\",\n  \"key_jsg587jhs\": \"escape\"\n}\n",
      "Each object in the original list has exactly one key but the keys are unique.",
      "I could do something like `jq .[] .genre` if the keys were the same but they're not.",
      "jq '[.[] | to_entries] | flatten | from_entries'",
      "jq 'add'"
    ],
    "utterance": "Combine a list where each element is a single-key object into a single object with all keys and values merged",
    "expressions": [
      "add",
      "[.[] | to_entries] | flatten | from_entries"
    ],
    "data": [
      {
        "input": [
          {
            "key_skjdghkbs": "deep house"
          },
          {
            "key_kjsskjbgs": "deadmau5"
          },
          {
            "key_jhw98w4hl": "progressive house"
          },
          {
            "key_sjkh348vg": "swedish house mafia"
          },
          {
            "key_js3485jwh": "dubstep"
          },
          {
            "key_jsg587jhs": "escape"
          }
        ],
        "output": {
          "key_skjdghkbs": "deep house",
          "key_kjsskjbgs": "deadmau5",
          "key_jhw98w4hl": "progressive house",
          "key_sjkh348vg": "swedish house mafia",
          "key_js3485jwh": "dubstep",
          "key_jsg587jhs": "escape"
        }
      }
    ],
    "identifier": 72296903
  },
  {
    "context": [
      "I would like to flatten the instances into a single list and insert the account_id into each instance. Here is the result that I want.",
      "jq '.|map(.instances[]+{\"account_id\": .account_id})' file.json",
      "If there are more instances, just iterate over all of them to distribute the account_id to each of them:",
      "jq '[.[] | .id = .instances[].id | del(.instances)]' file.json"
    ],
    "utterance": "Flatten all instances into a single list, adding the parent object's account_id into each instance.",
    "expressions": [
      ". | map(.instances[] + {account_id: .account_id})",
      "[.[] | .instances[] + {account_id: .account_id}]"
    ],
    "data": [
      {
        "input": [
          {
            "account_id": 123,
            "instances": [
              {
                "id": 1
              },
              {
                "id": 2
              }
            ]
          },
          {
            "account_id": 456,
            "instances": [
              {
                "id": 1
              }
            ]
          }
        ],
        "output": [
          {
            "id": 1,
            "account_id": 123
          },
          {
            "id": 2,
            "account_id": 123
          },
          {
            "id": 1,
            "account_id": 456
          }
        ]
      }
    ],
    "identifier": 72305617
  },
  {
    "context": [
      "The solution was to use `cat file.json | jq -c .` (note the dot that's added) in AWS.",
      "If you simply want to reformat the JSON, you can use the trivial program `.`.",
      "cat input.json | jq -c .",
      "If the input really is a file, the following is better:",
      "jq -c . input.json"
    ],
    "utterance": "Print a minified version of the file, preserving its structure, by applying the identity filter.",
    "expressions": [
      "jq -c . file.json",
      "cat file.json | jq -c ."
    ],
    "identifier": 72314169
  },
  {
    "context": [
      "echo 'REVIEW_REQUIRED_COUNT='$(jq '.data.resource.baseRepository.branchProtectionRules.nodes[] | .requiredApprovingReviewCount' data.json) >> $GITHUB_ENV",
      "I have run this exact query in the [GitHub GraphQL Explorer][1] and also checked my jq query in this [JQ Play snippet][2]. These both return the correct value (in my test case this is `1`).",
      "My expected output is: REVIEW_REQUIRED_COUNT= 1"
    ],
    "utterance": "Extract the requiredApprovingReviewCount value from the data structure at .data.resource.baseRepository.branchProtectionRules.nodes[].requiredApprovingReviewCount.",
    "expressions": [
      ".data.resource.baseRepository.branchProtectionRules.nodes[] | .requiredApprovingReviewCount"
    ],
    "data": [
      {
        "input": {
          "data": {
            "resource": {
              "baseRepository": {
                "branchProtectionRules": {
                  "nodes": [
                    {
                      "requiredApprovingReviewCount": 1
                    }
                  ]
                }
              }
            }
          }
        },
        "output": 1
      }
    ],
    "identifier": 72324237
  },
  {
    "context": [
      "I'm trying to update an existing json file from values in another json file using jq in a bash shell.",
      "How do I go about iterating over the values in the environment settings file such that I can use those values to update the base settings file for further processing (i.e., publishing to the target environment)?",
      "jq -s '.[1] as $insert | .[0].Settings |= $insert | .[0]' settings.json insert.json",
      "jq '.Settings = input' settings.json insert.json"
    ],
    "utterance": "Replace the values inside the Settings object of one file with all key-value pairs from a second file.",
    "expressions": [
      "jq -s '.[1] as $insert | .[0].Settings |= $insert | .[0]' settings.json insert.json",
      "jq '.Settings = input' settings.json insert.json"
    ],
    "data": [
      {
        "input": {
          "settings.json": {
            "Logging": {
              "MinimumLevel": {
                "Default": "Information",
                "Override": "Warning"
              },
              "WriteTo": [
                {
                  "Name": "File",
                  "Args": {
                    "path": "./logs/log-.txt",
                    "rollingInterval": "Day"
                  }
                }
              ]
            },
            "Settings": {
              "DataServerUrl": "https://address.to.server.com",
              "ServerKey": "1f969476798adfe95114dd28ed3a3ff",
              "ServerTimeZone": "Mountain Standard Time",
              "MaxOccupantCount": 6
            }
          },
          "insert.json": {
            "DataServerUrl": "https://dev.server.addr.com",
            "ServerKey": "2a4d99233efea456b95114aa23ed342ae"
          }
        },
        "output": {
          "Logging": {
            "MinimumLevel": {
              "Default": "Information",
              "Override": "Warning"
            },
            "WriteTo": [
              {
                "Name": "File",
                "Args": {
                  "path": "./logs/log-.txt",
                  "rollingInterval": "Day"
                }
              }
            ]
          },
          "Settings": {
            "DataServerUrl": "https://dev.server.addr.com",
            "ServerKey": "2a4d99233efea456b95114aa23ed342ae"
          }
        }
      }
    ],
    "identifier": 72307114
  },
  {
    "context": [
      "jq -c --stream 'fromstream(0|truncate_stream(inputs|select(.[0][0]==\"b\")| del(.[0][0:2])))' ex.json | split -l 4 --numeric-suffixes=1 - part_ --additional-suffix=.json",
      "\"the | in unix, it takes the output of the first command and sends it to the second so STDIN will contain all of the lines\"",
      "So the indicated command has the expected behavior."
    ],
    "utterance": "Split the array under key 'b' into multiple files, each containing 4 items.",
    "expressions": [
      "jq -c --stream 'fromstream(0|truncate_stream(inputs|select(.[0][0]==\"b\")| del(.[0][0:2])))' ex.json | split -l 4 --numeric-suffixes=1 - part_ --additional-suffix=.json"
    ],
    "data": [
      {
        "input": {
          "a": "some",
          "b": [
            {
              "d": "some"
            },
            {
              "d": "some"
            },
            {
              "d": "some"
            },
            {
              "d": "some"
            },
            {
              "d": "some"
            },
            {
              "d": "some"
            },
            {
              "d": "some"
            },
            {
              "d": "some"
            },
            {
              "d": "some"
            },
            {
              "d": "some"
            }
          ]
        },
        "output": [
          [
            {
              "d": "some"
            },
            {
              "d": "some"
            },
            {
              "d": "some"
            },
            {
              "d": "some"
            }
          ],
          [
            {
              "d": "some"
            },
            {
              "d": "some"
            },
            {
              "d": "some"
            },
            {
              "d": "some"
            }
          ],
          [
            {
              "d": "some"
            },
            {
              "d": "some"
            }
          ]
        ]
      }
    ],
    "identifier": 72324366
  },
  {
    "context": [
      "I need to modify the structure of this json file:",
      "in order to have this kind of output:\n[\n   {\n      \"id\":\"3333\",\n      \"properties\":{\n         \"label\":\"Computer\",\n         \"name\":\"My-Laptop\",\n         \"file_system\":[\n            \"/opt\",\n            \"/var\"\n         ]\n      }\n   }\n]",
      "As you can see the two partition are related to the first by the id and root_container.",
      "Is there an option to do this with jq functions or python script?",
      "You could employ `reduce` to iterate over the items while extracting their `id`, `mount_point` and `root_container`. Then, if a `root_container` was present, delete that entry and add its `mount_point` to the entry whose `id` matches their `root_container`. For convenience, I also employed `INDEX` on the items' `id` fields to simplify their access as `.[$id]` and `.[$root_container]`, which had to be undone at the end using `map(.)`.",
      "jq '\n  reduce .[] as {$id, properties: {$mount_point, $root_container}} (\n    INDEX(.id);\n    if $root_container then\n      del(.[$id])\n      | .[$root_container].properties.file_system += [$mount_point]\n    else . end\n  )\n  | map(.)\n'"
    ],
    "utterance": "Transform a list where partitions reference machines by root_container so each machine object contains a properties.file_system array listing the mount points of all partitions with matching root_container.",
    "expressions": [
      "reduce .[] as {$id, properties: {$mount_point, $root_container}} (\n  INDEX(.id);\n  if $root_container then\n    del(.[$id])\n    | .[$root_container].properties.file_system += [$mount_point]\n  else . end\n) | map(.)"
    ],
    "data": [
      {
        "input": [
          {
            "id": "3333",
            "properties": {
              "label": "Computer",
              "name": "My-Laptop"
            }
          },
          {
            "id": "9998",
            "type": "file_system",
            "properties": {
              "mount_point": "/opt",
              "name": "/dev/mapper/rhel-opt",
              "root_container": "3333"
            },
            "label": "FileSystem"
          },
          {
            "id": "9999",
            "type": "file_system",
            "properties": {
              "mount_point": "/var",
              "name": "/dev/mapper/rhel-var",
              "root_container": "3333"
            },
            "label": "FileSystem"
          }
        ],
        "output": [
          {
            "id": "3333",
            "properties": {
              "label": "Computer",
              "name": "My-Laptop",
              "file_system": [
                "/opt",
                "/var"
              ]
            }
          }
        ]
      }
    ],
    "identifier": 72306955
  },
  {
    "context": [
      "I need to retrieve a value from a yaml which I'm currently using yq for, like this:",
      "yq '.Resources.TestGlueJob.Properties.Name' cft/*.yaml",
      "where TestGlueJob can have different values. So I'm trying to use a wildcard like this, but that is giving me null as return value:",
      "yq '.Resources.*.Properties.Name' cft/*.yaml",
      "Have you tried using the object iterator `[]`?",
      "yq '.Resources[].Properties.Name' cft/*.yaml"
    ],
    "utterance": "Retrieve the Name property for all entries inside the Resources key, regardless of the resource name.",
    "expressions": [
      ".Resources[].Properties.Name"
    ],
    "identifier": 72360274
  },
  {
    "context": [
      "I would like output to have date price (in one line) with space or tab in between like",
      "1653004800000    2023.8482593608173",
      "possibly also format price to have 2 decimal places.  I was able to do it if I output only price like: ",
      "...|jq .price[][1]| xargs printf \"%'.2f\\n\"",
      "You can, for instance, have the items tab-separated by using @tsv. Alternatively, you can use the join function with a separator string.",
      "curl \u2026 | jq -r '.prices[] | @tsv'",
      "curl \u2026 | jq -r '.prices[] | join(\" | \")'",
      "To round the price column to two decimals, multiply it by 100, use round and divide again.",
      "curl \u2026 | jq -r '.prices[] | .[0] |= (./1000 | strftime(\"%d-%m-%Y\")) | .[1] |= (. * 100 | round / 100) | @tsv'"
    ],
    "utterance": "Output each entry from the prices array as a single line with the timestamp and price separated by a tab, and optionally format the price to two decimal places.",
    "expressions": [
      ".prices[] | @tsv",
      ".prices[] | join(\" | \")",
      ".prices[] | .[0] |= (./1000 | strftime(\"%d-%m-%Y\")) | .[1] |= (. * 100 | round / 100) | @tsv"
    ],
    "data": [
      {
        "input": {
          "prices": [
            [
              1652227200000,
              2344.797715643986
            ],
            [
              1652313600000,
              2080.910243657776
            ],
            [
              1652400000000,
              1966.6991711336661
            ]
          ]
        },
        "output": [
          "1652227200000\t2344.797715643986",
          "1652313600000\t2080.910243657776",
          "1652400000000\t1966.6991711336661"
        ]
      },
      {
        "input": {
          "prices": [
            [
              1652227200000,
              2344.797715643986
            ],
            [
              1652313600000,
              2080.910243657776
            ]
          ]
        },
        "output": [
          "11-05-2022\t2344.8",
          "12-05-2022\t2080.91"
        ]
      }
    ],
    "identifier": 72323773
  },
  {
    "context": [
      "I want to parse this using **jq** and sort the result based on the value of some common key, lets say the **\"foo\"** key.",
      "To sort, you need an array, which you can obtain using `--slurp`/`-s`.",
      "jq -sc 'sort_by( .foo )[]' input.log"
    ],
    "utterance": "Sort all objects in the input by the value of the \"foo\" key.",
    "expressions": [
      "sort_by(.foo)[]",
      "sort_by(.foo)"
    ],
    "data": [
      {
        "input": [
          {
            "foo": "1",
            "foo2": "2"
          },
          {
            "foo": "3",
            "foo2": "4"
          },
          {
            "foo": "5",
            "foo2": "6"
          },
          {
            "foo": "7",
            "foo2": "8"
          }
        ],
        "output": [
          {
            "foo": "1",
            "foo2": "2"
          },
          {
            "foo": "3",
            "foo2": "4"
          },
          {
            "foo": "5",
            "foo2": "6"
          },
          {
            "foo": "7",
            "foo2": "8"
          }
        ]
      }
    ],
    "identifier": 72411746
  },
  {
    "context": [
      "try to add `\"foo\": \"bar\"` to it using `jq`, the file `hello.json` becomes an empty file.",
      "$ cat hello.json | jq --arg bar bar '. + {foo: $bar}'  > hello.json",
      "$ cat hello.json",
      "On the other hand, if we had instead written the new JSON payload to `world.json`, we get the expected contents in `world.json`.",
      "Is there a way to do this **without installing new utilities** like `sponge`?",
      "You have to write to a different file and then copy it over your old file.",
      "As (generalized) code:",
      "$ cmd < file > file.tmp",
      "$ mv file.tmp file"
    ],
    "utterance": "Add a new key-value pair \"foo\": \"bar\" to the existing object in the input file and overwrite the original file atomically, without using extra utilities.",
    "expressions": [
      "jq --arg bar bar '. + {foo: $bar}' < hello.json > hello.json.tmp && mv hello.json.tmp hello.json",
      "jq --arg bar bar '. + {foo: $bar}' hello.json > hello.json.tmp && mv hello.json.tmp hello.json"
    ],
    "data": [
      {
        "input": {
          "hello": "world"
        },
        "output": {
          "hello": "world",
          "foo": "bar"
        }
      }
    ],
    "identifier": 72416842
  },
  {
    "context": [
      "I am trying to extract the value \"some subtitle\" from the array",
      "you could run the following to extract the value `\"Some subtitle\"`:",
      "jq .book.subtitle"
    ],
    "utterance": "Extract the value of the 'subtitle' field from the 'book' object.",
    "expressions": [
      ".book.subtitle"
    ],
    "data": [
      {
        "input": {
          "book": {
            "title": "Some title",
            "subtitle": "Some subtitle"
          }
        },
        "output": "Some subtitle"
      }
    ],
    "identifier": 72417184
  },
  {
    "context": [
      "Fields to extract:  \r\n    templates.name  \r\n    items.name  \r\n    triggers.name",
      "Output as:  \r\ntemplates.name; items.name; triggers.name",
      "Not every item has a trigger.  \r\nSeveral triggers may exist for an item.",
      ".zabbix_export.templates[] | .name as $tn | .items[] | [ $tn, .name, .triggers[]?.name? ] | join(\"; \")",
      "jq -r '\r\n  .[].templates[] | .name as $t\r\n  | .items[] | .name as $i\r\n  | [$t, $i, (.triggers[].name)? // \"\"]\r\n  | map(\"\\\"\\(.)\\\"\") | join(\"; \")\r\n'",
      "jq -r '\r\n  .[].templates[] | .name as $t\r\n  | .items[] | .name as $i\r\n  | [$t, $i, (.triggers[].name)? // \"\"]\r\n  | @csv\r\n'"
    ],
    "utterance": "Extract each template name, item name, and trigger name and output them as CSV lines with fields separated by semicolons; if an item has no triggers, the trigger name field should be empty, and if an item has multiple triggers, produce a line for each.",
    "expressions": [
      ".zabbix_export.templates[] | .name as $tn | .items[] | [ $tn, .name, .triggers[]?.name? ] | join(\"; \")",
      ".[].templates[] | .name as $t | .items[] | .name as $i | [$t, $i, (.triggers[].name)? // \"\"] | map(\"\\\"\\(.)\\\"\") | join(\"; \")"
    ],
    "data": [
      {
        "input": {
          "zabbix_export": {
            "version": "5.4",
            "date": "2022-05-17T06:25:59Z",
            "groups": [
              {
                "uuid": "7df96b18c230490a9a0a9e2307226338",
                "name": "Templates"
              }
            ],
            "templates": [
              {
                "uuid": "e60e6598cf19448089a5f5a6c5d796a2",
                "template": "Template App Agent",
                "name": "Template App Agent",
                "groups": [
                  {
                    "name": "Templates"
                  }
                ],
                "items": [
                  {
                    "uuid": "24c03ed734d54dc8868a282a83a02200",
                    "name": "Host name of zabbix_agentd running",
                    "key": "agent.hostname",
                    "delay": "1h",
                    "history": "1w",
                    "trends": "0",
                    "value_type": "CHAR",
                    "request_method": "POST",
                    "tags": [
                      {
                        "tag": "Application",
                        "value": "Zabbix agent"
                      }
                    ],
                    "triggers": [
                      {
                        "uuid": "d2d12d9e7dfe4fedb252f19b85e5e6aa",
                        "expression": "(last(/Template App Agent/agent.hostname,#1)<>last(/Template App Agent/agent.hostname,#2))>0",
                        "name": "Host name of zabbix_agentd was changed on {HOST.NAME}",
                        "priority": "INFO"
                      }
                    ]
                  },
                  {
                    "uuid": "abacad4ca5eb46d29864d8a4998f1cbb",
                    "name": "Agent ping",
                    "key": "agent.ping",
                    "history": "1w",
                    "description": "The agent always returns 1 for this item. It could be used in combination with nodata() for availability check.",
                    "valuemap": {
                      "name": "Zabbix agent ping status"
                    },
                    "request_method": "POST",
                    "tags": [
                      {
                        "tag": "Application",
                        "value": "Zabbix agent"
                      }
                    ],
                    "triggers": [
                      {
                        "uuid": "6d2a73199f3b4288bf36331a142c1725",
                        "expression": "nodata(/Template App Agent/agent.ping,5m)=1",
                        "name": "Zabbix agent on {HOST.NAME} is unreachable for 5 minutes",
                        "priority": "AVERAGE"
                      }
                    ]
                  },
                  {
                    "uuid": "2cc337555efd43d181c28c792f8cbbdb",
                    "name": "Version of zabbix_agent(d) running",
                    "key": "agent.version",
                    "delay": "1h",
                    "history": "1w",
                    "trends": "0",
                    "value_type": "CHAR",
                    "request_method": "POST",
                    "tags": [
                      {
                        "tag": "Application",
                        "value": "Zabbix agent"
                      }
                    ]
                  }
                ],
                "valuemaps": [
                  {
                    "uuid": "3d66c59a28c04b0ca8227c87902ddb4d",
                    "name": "Zabbix agent ping status",
                    "mappings": [
                      {
                        "value": "1",
                        "newvalue": "Up"
                      }
                    ]
                  }
                ]
              }
            ]
          }
        },
        "output": [
          "\"Template App Agent; Host name of zabbix_agentd running; Host name of zabbix_agentd was changed on {HOST.NAME}\"",
          "\"Template App Agent; Agent ping; Zabbix agent on {HOST.NAME} is unreachable for 5 minutes\"",
          "\"Template App Agent; Version of zabbix_agent(d) running\""
        ]
      }
    ],
    "identifier": 72271344
  },
  {
    "context": [
      "How can i use this variable to return the parent \"piece_cid\" ?",
      "Using a bash varible of $CAR with a value of baga6e~tlwdcmli__QmbHKa~G65fMXzh.car, id be able to get the results saved to $PIECE_CID with a value of baga6ea4seaqa24ucggxkliw4la4tkgvhevv3dacavovghsmnnscclt4tlwdcmli",
      "iterate over the `.response` array, then keep only those items for which `any` of the values in `.sources[].sample_retrieve_cmd` `contains` the given string, then output the value of `.piece_cid`",
      "jq -r --arg car \"$CAR\" '\n  .response[]\n  | select(any(.sources[].sample_retrieve_cmd; contains($car)))\n  | .piece_cid\n'"
    ],
    "utterance": "Find and return the value of piece_cid from a response array entry whose sources[].sample_retrieve_cmd contains a given string.",
    "expressions": [
      ".response[] | select(any(.sources[].sample_retrieve_cmd; contains($car))) | .piece_cid"
    ],
    "data": [
      {
        "input": {
          "response_code": 200,
          "response_entries": 2,
          "response": [
            {
              "piece_cid": "baga6ea4seaqa24ucggxkliw4la4tkgvhevv3dacavovghsmnnscclt4tlwdcmli",
              "dataset": "genome-ark",
              "padded_piece_size": 34359738368,
              "payload_cids": [
                "QmbHKaq6z321PqEG1BVLEAMpapq6YjkhdXpcs3G65fMXzh"
              ],
              "sources": [
                {
                  "source_type": "Filecoin",
                  "provider_id": "f0402371",
                  "deal_id": 1928414,
                  "original_payload_cid": "QmbHKaq6z321PqEG1BVLEAMpapq6YjkhdXpcs3G65fMXzh",
                  "deal_expiration": "2022-05-22T21:14:30Z",
                  "is_filplus": false,
                  "sector_id": null,
                  "sector_expires": null,
                  "sample_retrieve_cmd": "lotus client retrieve --provider f0402371 --maxPrice 0 --allow-local --car 'QmbHKaq6z321PqEG1BVLEAMpapq6YjkhdXpcs3G65fMXzh' $(pwd)/baga6e~tlwdcmli__QmbHKa~G65fMXzh.car"
                }
              ],
              "sample_request_cmd": "echo curl -sLH \\\"Authorization: $( ./fil-spid.bash f01826669 )\\\" https://api.evergreen.filecoin.io/request_piece/baga6ea4seaqa24ucggxkliw4la4tkgvhevv3dacavovghsmnnscclt4tlwdcmli | sh"
            },
            {
              "piece_cid": "baga6ea4seaqa2acwhwril5pm6n4muqlsrdkk27cgrqowz67himgbcwc3jhitina",
              "dataset": "genome-ark",
              "padded_piece_size": 34359738368,
              "payload_cids": [
                "QmSJc7g8sdUZKt2MqSDnrd1DXxxHow6XwKQZLcoCoCeW42"
              ],
              "sources": [
                {
                  "source_type": "Filecoin",
                  "provider_id": "f0402371",
                  "deal_id": 1927852,
                  "original_payload_cid": "QmSJc7g8sdUZKt2MqSDnrd1DXxxHow6XwKQZLcoCoCeW42",
                  "deal_expiration": "2022-05-22T20:11:00Z",
                  "is_filplus": false,
                  "sector_id": null,
                  "sector_expires": null,
                  "sample_retrieve_cmd": "lotus client retrieve --provider f0402371 --maxPrice 0 --allow-local --car 'QmSJc7g8sdUZKt2MqSDnrd1DXxxHow6XwKQZLcoCoCeW42' $(pwd)/baga6e~3jhitina__QmSJc7~oCoCeW42.car"
                }
              ],
              "sample_request_cmd": "echo curl -sLH \\\"Authorization: $( ./fil-spid.bash f01826669 )\\\" https://api.evergreen.filecoin.io/request_piece/baga6ea4seaqa2acwhwril5pm6n4muqlsrdkk27cgrqowz67himgbcwc3jhitina | sh"
            }
          ]
        },
        "output": "baga6ea4seaqa24ucggxkliw4la4tkgvhevv3dacavovghsmnnscclt4tlwdcmli"
      }
    ],
    "identifier": 72341360
  },
  {
    "context": [
      "This code puts all of the player data (both teams) for each game on one line of the csv. I would like one line per player in the csv.",
      "To generate one line of output per player, containing tid, ovr, won, lost, pid, gs, min, fg, and fga:",
      ".games[].teams[]\n  | . as $team\n  | .players[]\n  | [$team[\"tid\", \"ovr\", \"won\", \"lost\"], .pid, .gs, .min, .fg, .fga]\n  | join(\", \")",
      ".games[].teams[]\n  | . as $team\n  | .players[]\n  | [$team[\"tid\", \"ovr\", \"won\", \"lost\"], .[]]\n  | join(\", \")",
      "Although the next question is why use `join(\",\")` when jq already as has perfectly-fine `@csv` filter (automatically handling escaping etc.)?",
      ".games[].teams[]\n  | . as $team\n  | .players[]\n  | [$team[\"tid\", \"ovr\", \"won\", \"lost\"], .[]]\n  | @csv",
      "The variable-assignment to `$team` can be changed to a destructuring assignment:",
      ".games[].teams[]\n  | . as { $tid, $ovr, $won, $lost }\n  | .players[]\n  | [$tid, $ovr, $won, $lost, .[]]\n  | @csv"
    ],
    "utterance": "Output one line per player, each including the player's team's tid, ovr, won, lost, and the player's pid, gs, min, fg, and fga.",
    "expressions": [
      ".games[].teams[] | . as $team | .players[] | [$team[\"tid\", \"ovr\", \"won\", \"lost\"], .pid, .gs, .min, .fg, .fga] | join(\", \")",
      ".games[].teams[] | . as $team | .players[] | [$team[\"tid\", \"ovr\", \"won\", \"lost\"], .[]] | join(\", \")",
      ".games[].teams[] | . as $team | .players[] | [$team[\"tid\", \"ovr\", \"won\", \"lost\"], .[]] | @csv",
      ".games[].teams[] | . as { $tid, $ovr, $won, $lost } | .players[] | [$tid, $ovr, $won, $lost, .[]] | @csv"
    ],
    "data": [
      {
        "input": {
          "games": [
            {
              "teams": [
                {
                  "tid": 111,
                  "ovr": 112,
                  "won": 114,
                  "lost": 118,
                  "players": [
                    {
                      "pid": 11111,
                      "gs": 11112,
                      "min": 11114,
                      "fg": 11118,
                      "fga": 111116
                    },
                    {
                      "pid": 11121,
                      "gs": 11122,
                      "min": 11124,
                      "fg": 11128,
                      "fga": 111216
                    }
                  ]
                },
                {
                  "tid": 121,
                  "ovr": 122,
                  "won": 124,
                  "lost": 128,
                  "players": [
                    {
                      "pid": 12111,
                      "gs": 12112,
                      "min": 12114,
                      "fg": 12118,
                      "fga": 121116
                    },
                    {
                      "pid": 12121,
                      "gs": 12122,
                      "min": 12124,
                      "fg": 12128,
                      "fga": 121216
                    }
                  ]
                }
              ]
            },
            {
              "teams": [
                {
                  "tid": 211,
                  "ovr": 212,
                  "won": 214,
                  "lost": 218,
                  "players": [
                    {
                      "pid": 21111,
                      "gs": 21112,
                      "min": 21114,
                      "fg": 21118,
                      "fga": 211116
                    },
                    {
                      "pid": 21121,
                      "gs": 21122,
                      "min": 21124,
                      "fg": 21128,
                      "fga": 211216
                    }
                  ]
                },
                {
                  "tid": 221,
                  "ovr": 222,
                  "won": 224,
                  "lost": 228,
                  "players": [
                    {
                      "pid": 22111,
                      "gs": 22112,
                      "min": 22114,
                      "fg": 22118,
                      "fga": 221116
                    },
                    {
                      "pid": 22121,
                      "gs": 22122,
                      "min": 22124,
                      "fg": 22128,
                      "fga": 221216
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": [
          "111, 112, 114, 118, 11111, 11112, 11114, 11118, 111116",
          "111, 112, 114, 118, 11121, 11122, 11124, 11128, 111216",
          "121, 122, 124, 128, 12111, 12112, 12114, 12118, 121116",
          "121, 122, 124, 128, 12121, 12122, 12124, 12128, 121216",
          "211, 212, 214, 218, 21111, 21112, 21114, 21118, 211116",
          "211, 212, 214, 218, 21121, 21122, 21124, 21128, 211216",
          "221, 222, 224, 228, 22111, 22112, 22114, 22118, 221116",
          "221, 222, 224, 228, 22121, 22122, 22124, 22128, 221216"
        ]
      }
    ],
    "identifier": 72266922
  },
  {
    "context": [
      "I am trying to transform the data to the form.\n[\n {\n   \"title\": \"Some title\",\n   \"subtitle\": \"Some subtitle\"\n   \"price\": \"\u00a319.99\",\n   \"Chapter_no\": \"1\",\n   \"chapter_title\":\"foo\",\n },\n {\n   \"title\": \"Some title\",\n   \"subtitle\": \"Some subtitle\"\n   \"price\": \"\u00a319.99\",\n   \"Chapter_no\": \"2\",\n   \"chapter_title\":\"bar\",\n },\n ...\n]",
      "But I'm having difficulty trying to work out how to extract the fields from the previous arrays and add them to the chapter fields.",
      "It's easier to reconstruct `chapters` than update.\n[.book + {price} + .chapters[]]"
    ],
    "utterance": "For each element in the 'chapters' array, create an object containing all fields from 'book', the 'price', and the chapter's fields.",
    "expressions": [
      ".book + {price} + .chapters[] | [.]",
      "[.book + {price} + .chapters[]]"
    ],
    "data": [
      {
        "input": {
          "book": {
            "title": "Some title",
            "subtitle": "Some subtitle"
          },
          "price": "\u00a319.99",
          "chapters": [
            {
              "Chapter_no": "1",
              "chapter_title": "foo"
            },
            {
              "Chapter_no": "2",
              "chapter_title": "bar"
            },
            {
              "Chapter_no": "3",
              "chapter_title": "foobar"
            },
            {
              "Chapter_no": "4",
              "chapter_title": "fooandbar"
            }
          ]
        },
        "output": [
          {
            "title": "Some title",
            "subtitle": "Some subtitle",
            "price": "\u00a319.99",
            "Chapter_no": "1",
            "chapter_title": "foo"
          },
          {
            "title": "Some title",
            "subtitle": "Some subtitle",
            "price": "\u00a319.99",
            "Chapter_no": "2",
            "chapter_title": "bar"
          },
          {
            "title": "Some title",
            "subtitle": "Some subtitle",
            "price": "\u00a319.99",
            "Chapter_no": "3",
            "chapter_title": "foobar"
          },
          {
            "title": "Some title",
            "subtitle": "Some subtitle",
            "price": "\u00a319.99",
            "Chapter_no": "4",
            "chapter_title": "fooandbar"
          }
        ]
      }
    ],
    "identifier": 72415703
  },
  {
    "context": [
      "I need to filter PII data from a complex JSON object ***in one-pass*** with JQ.  ... I want to retain non-PII properties rather than remove PII properties because I want to avoid a PII leakage exposure if the backend adds a new PII property and doesn't let me know.",
      "Simplified Example of the Complex Object",
      "Input:",
      "{\n  \"customers\": [\n    {\n      \"id\": \"00000000001\",\n      \"dateOfBirth\": \"sensitive DOB\",\n      \"preferences\": [\n        {\n          \"preference-id\": \"0001\",\n          \"pii-value\": \"senstive value 1\"\n        },\n        {\n          \"preference-id\": \"0002\",\n          \"pii-value\": \"senstive value 2\"\n        }\n      ]\n    },\n    {\n      \"id\": \"00000000002\",\n      \"dateOfBirth\": \"sensitive DOB\",\n      \"preferences\": [\n        {\n          \"preference-id\": \"0003\",\n          \"pii-value\": \"senstive value 3\"\n        },\n        {\n          \"preference-id\": \"0004\",\n          \"pii-value\": \"senstive value 4\"\n        }\n      ]\n    }\n  ]\n}",
      "Desired Output:",
      "{\n  \"customers\": [\n    {\n      \"id\": \"00000000001\",\n      \"preferences\": [\n        {\n          \"preference-id\": \"0001\"\n        },\n        {\n          \"preference-id\": \"0002\"\n        }\n      ]\n    },\n    {\n      \"id\": \"00000000002\",\n      \"preferences\": [\n        {\n          \"preference-id\": \"0003\"\n        },\n        {\n          \"preference-id\": \"0004\"\n        }\n      ]\n    }\n  ]\n}",
      "Using a user function for *picking* specific paths from a JSON:",
      "def pick(paths):\n  . as $in\n  | reduce path(paths) as $path (null;\n    setpath($path; $in | getpath($path))\n  );\npick(.customers[] | .id, .preferences[].\"preference-id\")"
    ],
    "utterance": "Retain only the 'id' field for each customer and, for each customer, only the 'preference-id' field for each preference, discarding all other fields.",
    "expressions": [
      "def pick(paths):\n  . as $in\n  | reduce path(paths) as $path (null;\n    setpath($path; $in | getpath($path))\n  );\npick(.customers[] | .id, .preferences[].\"preference-id\")"
    ],
    "data": [
      {
        "input": {
          "customers": [
            {
              "id": "00000000001",
              "dateOfBirth": "sensitive DOB",
              "preferences": [
                {
                  "preference-id": "0001",
                  "pii-value": "senstive value 1"
                },
                {
                  "preference-id": "0002",
                  "pii-value": "senstive value 2"
                }
              ]
            },
            {
              "id": "00000000002",
              "dateOfBirth": "sensitive DOB",
              "preferences": [
                {
                  "preference-id": "0003",
                  "pii-value": "senstive value 3"
                },
                {
                  "preference-id": "0004",
                  "pii-value": "senstive value 4"
                }
              ]
            }
          ]
        },
        "output": {
          "customers": [
            {
              "id": "00000000001",
              "preferences": [
                {
                  "preference-id": "0001"
                },
                {
                  "preference-id": "0002"
                }
              ]
            },
            {
              "id": "00000000002",
              "preferences": [
                {
                  "preference-id": "0003"
                },
                {
                  "preference-id": "0004"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 72369864
  },
  {
    "context": [
      "Parent keys in this case are server names, and want to use JQ by to pull these over by selecting a specific country.",
      "I would have expected and want these results back:\n\nlondon1.perfect-privacy.com\nlondon2.perfect-privacy.com",
      "to_entries[] | select( .value.country_short == \"gb\" ) | .key",
      "path(.[] | select(.country == \"United Kingdom\"))[0]"
    ],
    "utterance": "Return all top-level keys whose country field has the value 'United Kingdom'.",
    "expressions": [
      "to_entries[] | select(.value.country == \"United Kingdom\") | .key",
      "path(.[] | select(.country == \"United Kingdom\"))[0]"
    ],
    "data": [
      {
        "input": {
          "london1.perfect-privacy.com": {
            "city": "London",
            "city_short": "lo",
            "country": "United Kingdom",
            "country_short": "gb",
            "lati": "51.511214",
            "longi": "-0.119824"
          },
          "london2.perfect-privacy.com": {
            "city": "London",
            "city_short": "lo",
            "country": "United Kingdom",
            "country_short": "gb",
            "lati": "51.511214",
            "longi": "-0.119824"
          },
          "rotterdam2.perfect-privacy.com": {
            "city": "Rotterdam",
            "city_short": "ro",
            "country": "Netherlands",
            "country_short": "nl",
            "lati": "51.924216",
            "longi": "4.481776"
          }
        },
        "output": [
          "london1.perfect-privacy.com",
          "london2.perfect-privacy.com"
        ]
      }
    ],
    "identifier": 72420520
  },
  {
    "context": [
      "I am trying to output the value for nested json key but for some reason I get null value.",
      "Curl response looks like this \n{\ntag info:{ id: \"12\"  , name:...}}",
      "jq -r --arg e \"tagInfo.id\" '.[$e]' <<< '{\"tagInfo\":{ \"id\": \"12\" , \"name\": \"aname\"}}'",
      "2. Specify the path as an array:\n\njq -r --argjson e '[\"tagInfo\", \"id\"]' 'getpath($e)' <<< '{\"tagInfo\":{ \"id\": \"12\" , \"name\": \"aname\"}}'"
    ],
    "utterance": "Retrieve the value of the nested key 'id' inside the 'tagInfo' object where the path elements are provided as an array variable.",
    "expressions": [
      "jq -r --argjson e '[\"tagInfo\", \"id\"]' 'getpath($e)'"
    ],
    "data": [
      {
        "input": {
          "tagInfo": {
            "id": "12",
            "name": "aname"
          }
        },
        "output": "12"
      }
    ],
    "identifier": 72423939
  },
  {
    "context": [
      "How do I instead get line-by-line output, no brackets, quotes, or commas, like this:\n\n    x1\n    x2\n    y1\n    y2",
      "% jq -r '.a[].b[]' tmp.json",
      "jq -r '(.[] | .[].b)[]'  Input_file"
    ],
    "utterance": "Print every string from all b arrays inside objects within top-level a, one per line, with no extra formatting.",
    "expressions": [
      ".a[].b[]",
      "(.[] | .[].b)[]"
    ],
    "data": [
      {
        "input": {
          "a": [
            {
              "b": [
                "x1",
                "x2"
              ],
              "z": "z"
            },
            {
              "b": [
                "y1",
                "y2"
              ],
              "w": "w"
            }
          ]
        },
        "output": [
          "x1",
          "x2",
          "y1",
          "y2"
        ]
      }
    ],
    "identifier": 72452280
  },
  {
    "context": [
      "But, in the script that I am doing, the number is given from another command, something similar to this next for simplicity. And at the time of executing it, it does not parse the variable or the quotes well. So the result be null.",
      "ID=$(echo \"2\")",
      "jq --raw-output '.\"$ID\".job' README.md",
      "Instead, pass the number as an *argument* to the filter.",
      "ID=2",
      "jq --raw-output --arg x \"$ID\"  '.[$x].job' data.txt"
    ],
    "utterance": "Retrieve the 'job' value for a user, where the user id is stored in a shell variable, by passing the variable as an argument.",
    "expressions": [
      "jq --raw-output --arg x \"$ID\" '.[$x].job' data.txt"
    ],
    "data": [
      {
        "input": {
          "1": {
            "job": "Plumber",
            "age": "23"
          },
          "2": {
            "job": "SEO",
            "age": "45"
          }
        },
        "output": "SEO"
      }
    ],
    "identifier": 72452978
  },
  {
    "context": [
      "But I can't figure out how to print\n\n    hostname1\n              \"owner:TEAM_A\",\n              \"friendlyname:myhost1\",\n    hostname2\n              \"owner:TEAM_A\",\n              \"friendlyname:myhost2\",\n    hostname3\n              \"owner:TEAM_A\",\n              \"friendlyname:myhost3\",",
      "Another example:\n~~~sh\njq -r '\n  .rows[] | to_entries[] | [.key, (\n    .value.tags[] | select(startswith(\"owner:\"), \"friendlyname:\"))\n  )] | join(\"\\n \")\n'\n~~~",
      "Turning `tags` into an object first would make it easier to retrieve tags in a particular order.\n```\n.rows[][].tags | INDEX(sub(\":.*\"; \"\")) | .owner, .friendlyname\n```",
      ".rows[]\n| keys_unsorted[] as $hostname\n| .[$hostname].tags\n| INDEX(sub(\":.*\"; \"\"))\n| $hostname, \"\\t\" + (.owner, .friendlyname)"
    ],
    "utterance": "For each host, print the hostname followed by its 'owner' and 'friendlyname' tag values, regardless of their position in the tags array.",
    "expressions": [
      ".rows[] | to_entries[] | [.key, (.value.tags[] | select(startswith(\"owner:\"), \"friendlyname:\"))] | join(\"\\n \")",
      ".rows[][] | [. as $o | keys_unsorted[] as $h | $h, ($o[$h].tags[] | select(startswith(\"owner:\"), startswith(\"friendlyname:\")))] | join(\"\\n \")",
      ".rows[][].tags | INDEX(sub(\":.*\"; \"\")) | .owner, .friendlyname",
      ".rows[] | keys_unsorted[] as $hostname | .[$hostname].tags | INDEX(sub(\":.*\"; \"\")) | $hostname, \"\\t\" + (.owner, .friendlyname)"
    ],
    "data": [
      {
        "input": {
          "results": 3,
          "rows": [
            {
              "hostname1": {
                "tags": [
                  "owner:TEAM_A",
                  "friendlyname:myhost1",
                  "x:abc",
                  "y:jkl"
                ]
              }
            },
            {
              "hostname2": {
                "tags": [
                  "friendlyname:myhost2",
                  "owner:TEAM_A",
                  "x:def",
                  "q:jkl"
                ]
              }
            },
            {
              "hostname3": {
                "tags": [
                  "owner:TEAM_A",
                  "x:ghi",
                  "friendlyname:myhost3",
                  "q:jkl"
                ]
              }
            }
          ]
        },
        "output": "hostname1\nowner:TEAM_A\nfriendlyname:myhost1\nhostname2\nowner:TEAM_A\nfriendlyname:myhost2\nhostname3\nowner:TEAM_A\nfriendlyname:myhost3"
      }
    ],
    "identifier": 72419470
  },
  {
    "context": [
      "I get a field with jq with:",
      "jq -r '.statuses[]   | \"\\(.name);\\(.startTime);\\(.ord);\\(.app);\\(.group)\"'",
      "It gives me:",
      "HOSUE;20220601101600;220601;BANDOL;FLASH",
      "I would like to get:",
      "HOUSE;2022-06-01 10:16:00;220601;BANDOL;FLASH",
      "You can use the `sub` filter:",
      "\"20220601101600\" | sub(\"^(?<year>....)(?<mo>..)(?<day>..)(?<h>..)(?<m>..)(?<s>..)$\"; \"\\(.year)-\\(.mo)-\\(.day) \\(.h):\\(.m):\\(.s)\")",
      "To slice by position, use the `.[<from>:<to>]` notation:",
      ".startTime | \"\\(.[0:4])-\\(.[4:6])-\\(.[6:8]) \\(.[8:10]):\\(.[10:12]):\\(.[12:14])\""
    ],
    "utterance": "Format the 'startTime' field from '20220601101600' to '2022-06-01 10:16:00' while outputting all requested fields with semicolon separators.",
    "expressions": [
      ".statuses[] | \"\\(.name);\\(.startTime | sub(\"^(?<year>....)(?<mo>..)(?<day>..)(?<h>..)(?<m>..)(?<s>..)$\"; \"\\(.year)-\\(.mo)-\\(.day) \\(.h):\\(.m):\\(.s)\"));\\(.ord);\\(.app);\\(.group)\"",
      ".statuses[] | \"\\(.name);\\(.startTime | \"\\(.[0:4])-\\(.[4:6])-\\(.[6:8]) \\(.[8:10]):\\(.[10:12]):\\(.[12:14])\");\\(.ord);\\(.app);\\(.group)\""
    ],
    "data": [
      {
        "input": {
          "statuses": [
            {
              "name": "HOUSE",
              "startTime": "20220601101600",
              "ord": "220601",
              "app": "BANDOL",
              "group": "FLASH"
            }
          ]
        },
        "output": [
          "HOUSE;2022-06-01 10:16:00;220601;BANDOL;FLASH"
        ]
      }
    ],
    "identifier": 72458534
  },
  {
    "context": [
      "i.e. select *IP* and port if *service_name* is equal to *HTTP*. I know how to get IP `jq -r '.[].result.hits[] | select(.services[].service_name == \"HTTP\") | .ip'` and also how to get only ports `jq -r '.[].result.hits[].services[] | select(.service_name == \"HTTP\") | .port'`, but I do not understand how to combine it properly in one command. Could someone please point to a right direction?",
      "jq -r '.[].result.hits[] | .ip as $ip | .services[] | select(.service_name == \"HTTP\") | \"\\($ip):\\(.port)\"'",
      "jq -r '.[].result.hits[] | \"\\(.ip):\\(.services[] | select(.service_name==\"HTTP\").port)\"' file",
      "2.14.11.41:80",
      "2.14.11.41:8001",
      "2.22.22.102:80",
      "2.22.22.102:8001",
      "2.22.22.102:8089",
      "4.54.84.19:443"
    ],
    "utterance": "List IP and port pairs where service_name is HTTP, formatted as ip:port.",
    "expressions": [
      ".[].result.hits[] | .ip as $ip | .services[] | select(.service_name == \"HTTP\") | \"\\($ip):\\(.port)\"",
      ".[].result.hits[] | \"\\(.ip):\\(.services[] | select(.service_name==\\\"HTTP\\\").port)\""
    ],
    "data": [
      {
        "input": [
          {
            "code": 200,
            "status": "OK",
            "result": {
              "query": "123",
              "hits": [
                {
                  "ip": "2.14.11.41",
                  "services": [
                    {
                      "port": 22,
                      "service_name": "SSH",
                      "transport_protocol": "TCP"
                    },
                    {
                      "port": 80,
                      "service_name": "HTTP",
                      "transport_protocol": "TCP"
                    },
                    {
                      "port": 5900,
                      "service_name": "VNC",
                      "transport_protocol": "TCP"
                    },
                    {
                      "port": 8001,
                      "service_name": "HTTP",
                      "certificate": "62345a087218e",
                      "transport_protocol": "TCP"
                    }
                  ],
                  "location": {
                    "continent": "Asia",
                    "country": "Israel",
                    "country_code": "IL",
                    "timezone": "Asia/Jerusalem",
                    "coordinates": {
                      "latitude": 31.5,
                      "longitude": 34.75
                    },
                    "registered_country": "Israel",
                    "registered_country_code": "IL"
                  },
                  "autonomous_system": {
                    "asn": 12400,
                    "description": "PARTNER-AS",
                    "bgp_prefix": "2.54.0.0/17",
                    "name": "PARTNER-AS",
                    "country_code": "IL"
                  },
                  "last_updated_at": "2022-05-18T13:09:19.288Z"
                },
                {
                  "ip": "2.22.22.102",
                  "services": [
                    {
                      "port": 22,
                      "service_name": "SSH",
                      "transport_protocol": "TCP"
                    },
                    {
                      "port": 80,
                      "service_name": "HTTP",
                      "transport_protocol": "TCP"
                    },
                    {
                      "port": 5901,
                      "service_name": "VNC",
                      "transport_protocol": "TCP"
                    },
                    {
                      "port": 8001,
                      "service_name": "HTTP",
                      "certificate": "6875897649b700a087218e",
                      "transport_protocol": "TCP"
                    },
                    {
                      "port": 8089,
                      "service_name": "HTTP",
                      "transport_protocol": "TCP"
                    }
                  ],
                  "location": {
                    "continent": "Asia",
                    "country": "Israel",
                    "country_code": "IL",
                    "city": "Herzliya",
                    "timezone": "Asia/Jerusalem",
                    "province": "Tel Aviv",
                    "coordinates": {
                      "latitude": 32.1679,
                      "longitude": 34.834
                    },
                    "registered_country": "Israel",
                    "registered_country_code": "IL"
                  },
                  "autonomous_system": {
                    "asn": 12400,
                    "description": "PARTNER-AS",
                    "bgp_prefix": "2.55.0.0/17",
                    "name": "PARTNER-AS",
                    "country_code": "IL"
                  },
                  "last_updated_at": "2022-05-18T13:50:58.807Z"
                },
                {
                  "ip": "4.54.84.19",
                  "services": [
                    {
                      "port": 22,
                      "service_name": "SSH",
                      "transport_protocol": "TCP"
                    },
                    {
                      "port": 443,
                      "service_name": "HTTP",
                      "certificate": "8120978819a83e",
                      "transport_protocol": "TCP"
                    },
                    {
                      "port": 502,
                      "service_name": "MODBUS",
                      "transport_protocol": "TCP"
                    },
                    {
                      "port": 5900,
                      "service_name": "VNC",
                      "transport_protocol": "TCP"
                    }
                  ],
                  "location": {
                    "continent": "Asia",
                    "country": "Israel",
                    "country_code": "IL",
                    "city": "Ashdod",
                    "timezone": "Asia/Jerusalem",
                    "province": "Southern District",
                    "coordinates": {
                      "latitude": 31.7915,
                      "longitude": 34.6497
                    },
                    "registered_country": "Israel",
                    "registered_country_code": "IL"
                  },
                  "autonomous_system": {
                    "asn": 12400,
                    "description": "PARTNER-AS",
                    "bgp_prefix": "2.55.0.0/17",
                    "name": "PARTNER-AS",
                    "country_code": "IL"
                  },
                  "last_updated_at": "2022-05-18T12:36:13.141Z"
                }
              ],
              "links": {
                "next": "eyJ9I6MH0=",
                "prev": ""
              }
            }
          }
        ],
        "output": [
          "2.14.11.41:80",
          "2.14.11.41:8001",
          "2.22.22.102:80",
          "2.22.22.102:8001",
          "2.22.22.102:8089",
          "4.54.84.19:443"
        ]
      }
    ],
    "identifier": 72294619
  },
  {
    "context": [
      "I would like to check for the presence of a subkey (or for its type) in a JSON file using jq without filtering the data.",
      "I need this to obtain a list of all entities from the following JSON file, with the first pair of coordinates if more than one pair is available.",
      "The \"location\" object is only available for some entries, and the \"coordinates\" element is an array only if multiple locations are available.",
      "I hoped to get a JSON output similar to this (but I would be happy to handle other formats):\n{\n\"records\":[\n{\"id\": 1, \"lat\", xx, \"lon\": xx}\n{\"id\": 2, \"lat\", yy, \"lon\": yy}\n{\"id\": 3, \"lat\", null, \"lon\": null}\n]}",
      ".records |= map(.id as $id | (.location.coordinates | (if type == \"array\" then .[0] else . end) as $q | ({ $id, lat: null, lon: null } + $q) ))",
      "You can also use alternative operator // :\n\njq '.records[] |= {id}+((.location.coordinates? |\n                         if type == \"array\" then .[0] else . end\n                        ) // {}\n                       )' input.json",
      ".records[] |= (.location.coordinates | .[0]? // .) as {$lat,$lon} | {id,$lat,$lon}",
      "jq '.records |= map(\n  .location as {coordinates: [{$lat, $lon}]} ?// {coordinates: {$lat, $lon}}\n  | {id, $lat, $lon}\n)'"
    ],
    "utterance": "For each record, extract id, and the first pair of coordinates as lat and lon (or null if missing), even when location or coordinates are absent or in differing formats.",
    "expressions": [
      ".records |= map(.id as $id | (.location.coordinates | (if type == \"array\" then .[0] else . end) as $q | ({ $id, lat: null, lon: null } + $q) ))",
      ".records[] |= {id}+((.location.coordinates? | if type == \"array\" then .[0] else . end ) // {} )",
      ".records[] |= (.location.coordinates | .[0]? // .) as {$lat,$lon} | {id,$lat,$lon}",
      ".records |= map(\n  .location as {coordinates: [{$lat, $lon}]} ?// {coordinates: {$lat, $lon}}\n  | {id, $lat, $lon}\n)"
    ],
    "data": [
      {
        "input": {
          "records": [
            {
              "id": 1,
              "location": {
                "coordinates": {
                  "lat": 42,
                  "lon": -71
                }
              }
            },
            {
              "id": 2,
              "location": {
                "coordinates": [
                  {
                    "lat": 40,
                    "lon": -73
                  },
                  {
                    "lat": 39,
                    "lon": -75
                  }
                ]
              }
            },
            {
              "id": 3,
              "location": null
            }
          ]
        },
        "output": {
          "records": [
            {
              "id": 1,
              "lat": 42,
              "lon": -71
            },
            {
              "id": 2,
              "lat": 40,
              "lon": -73
            },
            {
              "id": 3,
              "lat": null,
              "lon": null
            }
          ]
        }
      }
    ],
    "identifier": 72432986
  },
  {
    "context": [
      "I have this data. {\"bucket\":\"sdsd\",\"key\":\"hghghg\",\"region\":\"us-east-1\"}",
      "I want to convert it into following format. using shell commands.",
      "- \"bucekt\"=\"sdsd\"",
      "- \"key\"=\"hghghg\"",
      "- \"region\"=\"us-east-1\"",
      "Use `to_entries` to access keys and values. To escape with quotes, it may not be sufficient to just put quotes around the names. Depending on your use case, converting to JSON strings using `@json` might be an option:",
      "jq -r 'to_entries[] | @json \"\\(.key) = \\(.value)\"'",
      "\"bucket\" = \"sdsd\"",
      "\"key\" = \"hghghg\"",
      "\"region\" = \"us-east-1\""
    ],
    "utterance": "Produce output lines with each key and value surrounded by double quotes, formatted as \"key\" = \"value\" for every key-value pair in the object.",
    "expressions": [
      "to_entries[] | '\"' + .key + '\" = \"' + .value + '\"'",
      ". as $o | keys[] | '\"' + . + '\" = \"' + $o[.] + '\"'"
    ],
    "data": [
      {
        "input": {
          "bucket": "sdsd",
          "key": "hghghg",
          "region": "us-east-1"
        },
        "output": [
          "\"bucket\" = \"sdsd\"",
          "\"key\" = \"hghghg\"",
          "\"region\" = \"us-east-1\""
        ]
      }
    ],
    "identifier": 72463522
  },
  {
    "context": [
      "I am trying to create a new file adding the object defined in country1.json into world.json.",
      "Using the filename for the objects in country1.json file.",
      "jq '.country1 = input' world.json country1.json > world_country1.json",
      "If you want to utilize the file's name for the new field's name, use input_filename and cut off the last 5 characters (removing .json):",
      "jq '. + (input | {(input_filename[:-5]): .})' world.json country1.json > world_country1.json"
    ],
    "utterance": "Combine two objects by adding the contents of one file as a new field named after its filename (without .json) into another object.",
    "expressions": [
      ".country1 = input",
      ". + (input | {(input_filename[:-5]): .})"
    ],
    "data": [
      {
        "input": {
          "world.json": {
            "class": "world",
            "version": "1.1.0"
          },
          "country1.json": {
            "class": "country",
            "country_1": {
              "class": "city",
              "name": "seattle"
            }
          }
        },
        "output": {
          "class": "world",
          "version": "1.1.0",
          "country1": {
            "class": "country",
            "country_1": {
              "class": "city",
              "name": "seattle"
            }
          }
        }
      }
    ],
    "identifier": 72466437
  },
  {
    "context": [
      "But when I try to retrieve internal values, getting error as below.",
      "aws secretsmanager get-secret-value --secret-id ssh_key --version-stage AWSCURRENT | jq '.SecretString.ssh_key'",
      "jq: error (at <stdin>:10): Cannot index string with string \"ssh_key\"",
      "With a single call to `jq` :",
      "jq -r '.SecretString|fromjson|.ssh_key'"
    ],
    "utterance": "Given command output, extract the value associated with the key 'ssh_key' inside the JSON string stored in 'SecretString'.",
    "expressions": [
      ".SecretString | fromjson | .ssh_key"
    ],
    "data": [
      {
        "input": {
          "Name": "ssh_key",
          "VersionId": "1c8acb5c-26e5-4991-b45d-ddd7e7769ebf",
          "SecretString": "{\"ssh_key\":\"-----BEGIN RSA PRIVATE KEY----- ... -----END RSA PRIVATE KEY-----\",\"some\":\"value\"}",
          "VersionStages": [
            "AWSCURRENT"
          ],
          "CreatedDate": 1654095742.095,
          "ARN": "arn:aws:secretsmanager:us-west-2:<accountid>:secret:ssh_key-Jmv1r1"
        },
        "output": "-----BEGIN RSA PRIVATE KEY----- ... -----END RSA PRIVATE KEY-----"
      }
    ],
    "identifier": 72465049
  },
  {
    "context": [
      "Is there a way i can fetch the latest stable version only? For example , i want to fetch 8.0.29 as it is the latest stable version for 8x version . And next time when 8.0.30 comes i get the output from the same command?",
      "jq -r 'map(.name) | sort_by(scan(\"\\\\d+\") | tonumber)[-1]'",
      "If for the output you only want the pure version number (`8.0.29` instead of `8.0.29-oracle`), ditch everything after and including the dash sign:",
      "jq -r 'map(.name | .[:index(\"-\")]) | sort_by(scan(\"\\\\d+\") | tonumber)[-1]'"
    ],
    "utterance": "Return the latest tag comprised of three numeric dot-separated segments, such as 8.0.29, excluding any tag with suffixes like -debian or -oracle.",
    "expressions": [
      "map(.name | .[:index(\"-\")]) | sort_by(scan(\"\\d+\") | tonumber)[-1]"
    ],
    "data": [
      {
        "input": [
          {
            "name": "5.7.38"
          },
          {
            "name": "5.7.38-debian"
          },
          {
            "name": "5.7.38-oracle"
          },
          {
            "name": "5.7.4"
          },
          {
            "name": "5.7.4-m14"
          },
          {
            "name": "5.7.5"
          },
          {
            "name": "5.7.5-m15"
          },
          {
            "name": "5.7.6"
          },
          {
            "name": "5.7.6-m16"
          },
          {
            "name": "5.7.7"
          },
          {
            "name": "5.7.7-rc"
          },
          {
            "name": "5.7.8"
          },
          {
            "name": "5.7.8-rc"
          },
          {
            "name": "5.7.9"
          },
          {
            "name": "8"
          },
          {
            "name": "8-debian"
          },
          {
            "name": "8-oracle"
          },
          {
            "name": "8.0"
          },
          {
            "name": "8.0-debian"
          },
          {
            "name": "8.0-oracle"
          },
          {
            "name": "8.0.0"
          },
          {
            "name": "8.0.1"
          },
          {
            "name": "8.0.11"
          },
          {
            "name": "8.0.12"
          },
          {
            "name": "8.0.13"
          },
          {
            "name": "8.0.14"
          },
          {
            "name": "8.0.15"
          },
          {
            "name": "8.0.16"
          },
          {
            "name": "8.0.17"
          },
          {
            "name": "8.0.18"
          },
          {
            "name": "8.0.19"
          },
          {
            "name": "8.0.2"
          },
          {
            "name": "8.0.20"
          },
          {
            "name": "8.0.21"
          },
          {
            "name": "8.0.22"
          },
          {
            "name": "8.0.23"
          },
          {
            "name": "8.0.24"
          },
          {
            "name": "8.0.25"
          },
          {
            "name": "8.0.26"
          },
          {
            "name": "8.0.27"
          },
          {
            "name": "8.0.28"
          },
          {
            "name": "8.0.28-debian"
          },
          {
            "name": "8.0.28-oracle"
          },
          {
            "name": "8.0.29"
          },
          {
            "name": "8.0.29-debian"
          },
          {
            "name": "8.0.29-oracle"
          },
          {
            "name": "8.0.3"
          },
          {
            "name": "8.0.4"
          },
          {
            "name": "8.0.4-rc"
          },
          {
            "name": "debian"
          },
          {
            "name": "oracle"
          }
        ],
        "output": "8.0.29"
      }
    ],
    "identifier": 72461219
  },
  {
    "context": [
      "Objective:\n\nI want to filter json file by specific key name and to get only its value as output",
      "filter to be used: id (in below json)",
      "{\n  \"name\": \"abotcontext7\",\n  \"id\": \"20436855-4635-49c0-8cc9-a389c569233b\",\n  \"created_at\": \"2022-06-02T10:39:48.280Z\"\n}",
      "Output should be just: `20436855-4635-49c0-8cc9-a389c569233b`",
      "I tried  cat /tmp/output.json|jq -r '.id[]",
      "As per @pmf suggestion it worked\n\n    jq -r 'values.id' /tmp/output.json"
    ],
    "utterance": "Extract the value associated with the key 'id' from the input, outputting only that value.",
    "expressions": [
      ".id",
      "values.id"
    ],
    "data": [
      {
        "input": {
          "name": "abotcontext7",
          "id": "20436855-4635-49c0-8cc9-a389c569233b",
          "created_at": "2022-06-02T10:39:48.280Z"
        },
        "output": "20436855-4635-49c0-8cc9-a389c569233b"
      }
    ],
    "identifier": 72475049
  },
  {
    "context": [
      "I have a JSON-file like the one below:",
      "{\n\t\"Results\": [\n\t\t{\n\t\t\t\"Severity\": \"LOW\",\n\t\t\t\"InstalledVersion\": \"1.21.1ubuntu2\",\n\t\t\t\"FixedVersion\": \"1.21.1ubuntu2.1\"\n\t\t},\n\t\t{\n\t\t\t\"Severity\": \"LOW\",\n\t\t\t\"InstalledVersion\": \"1.21.1ubuntu2\"\n\t\t},\n\t\t{\n\t\t\t\"Severity\": \"HIGH\",\n\t\t\t\"VulnerabilityID\": \"CVE-2016-2781\"\n\t\t}\n\t]\n}",
      "I would like to create the following JSON-file:",
      "[\n\t{\n\t\t\"Severity\": \"LOW\",\n\t\t\"InstalledVersion\": \"1.21.1ubuntu2\",\n\t\t\"FixedVersion\": \"1.21.1ubuntu2.1\",\n\t\t\"VulnerabilityID\": \"\"\n\t},\n\t{\n\t\t\"Severity\": \"LOW\",\n\t\t\"InstalledVersion\": \"1.21.1ubuntu2\",\n\t\t\"FixedVersion\": \"\",\n\t\t\"VulnerabilityID\": \"\"\n\t},\n\t{\n\t\t\"Severity\": \"HIGH\",\n\t\t\"InstalledVersion\": \"\",\n\t\t\"FixedVersion\": \"\",\n\t\t\"VulnerabilityID\": \"CVE-2016-2781\"\n\t}\n]",
      "jq '[ .Results[] | {Severity:\"\", InstalledVersion:\"\", FixedVersion:\"\", VulnerabilityID:\"\"} + . ]' input.json",
      "[ .Results[] | . + { VulnerabilityID: (.VulnerabilityID // \"\"), FixedVersion: (.FixedVersion // \"\"), InstalledVersion: (.InstalledVersion // \"\") } ]",
      "jq '[\n    .Results[]\n    | .FixedVersion //= \"\"\n    | .VulnerabilityID //= \"\"\n    | .InstalledVersion //= \"\"\n]' file.json",
      "jq '.Results |\n    (map(keys)|add|unique|map({key:.,value:\"\"})|from_entries) as $default |\n    map($default + .)\n   ' input.json"
    ],
    "utterance": "For each object in the Results array, include the keys Severity, InstalledVersion, FixedVersion, and VulnerabilityID, setting any missing values to an empty string.",
    "expressions": [
      "[ .Results[] | . + { VulnerabilityID: (.VulnerabilityID // \"\"), FixedVersion: (.FixedVersion // \"\"), InstalledVersion: (.InstalledVersion // \"\") } ]",
      "[ .Results[] | {Severity:\"\", InstalledVersion:\"\", FixedVersion:\"\", VulnerabilityID:\"\"} + . ]",
      "[\n    .Results[]\n    | .FixedVersion //= \"\"\n    | .VulnerabilityID //= \"\"\n    | .InstalledVersion //= \"\"\n]",
      ".Results |\n    (map(keys)|add|unique|map({key:.,value:\"\"})|from_entries) as $default |\n    map($default + .)"
    ],
    "data": [
      {
        "input": {
          "Results": [
            {
              "Severity": "LOW",
              "InstalledVersion": "1.21.1ubuntu2",
              "FixedVersion": "1.21.1ubuntu2.1"
            },
            {
              "Severity": "LOW",
              "InstalledVersion": "1.21.1ubuntu2"
            },
            {
              "Severity": "HIGH",
              "VulnerabilityID": "CVE-2016-2781"
            }
          ]
        },
        "output": [
          {
            "Severity": "LOW",
            "InstalledVersion": "1.21.1ubuntu2",
            "FixedVersion": "1.21.1ubuntu2.1",
            "VulnerabilityID": ""
          },
          {
            "Severity": "LOW",
            "InstalledVersion": "1.21.1ubuntu2",
            "FixedVersion": "",
            "VulnerabilityID": ""
          },
          {
            "Severity": "HIGH",
            "InstalledVersion": "",
            "FixedVersion": "",
            "VulnerabilityID": "CVE-2016-2781"
          }
        ]
      }
    ],
    "identifier": 72462640
  },
  {
    "context": [
      "When the expr key contains value that includes something like \"sum((rate\" I want to append to the value another string.",
      ".dashboard.panels[].targets[].expr |= if contains(\"sum((rate\") then . + \"TEST\" else . end",
      "(.dashboard.panels[].targets[].expr | select(contains(\"sum((rate\"))) += \"TEST\""
    ],
    "utterance": "Append 'TEST' to all expr values under dashboard.panels[].targets[] that contain 'sum((rate'.",
    "expressions": [
      ".dashboard.panels[].targets[].expr |= if contains(\"sum((rate\") then . + \"TEST\" else . end",
      ".dashboard.panels[].targets[].expr |= . + (if contains(\"sum((rate\") then \"TEST\" else \"\" end)",
      "(.dashboard.panels[].targets[].expr | select(contains(\"sum((rate\"))) += \"TEST\""
    ],
    "data": [
      {
        "input": {
          "dashboard": {
            "panels": [
              {
                "targets": [
                  {
                    "expr": "sum((rate(foo)))"
                  },
                  {
                    "expr": "avg(bar)"
                  }
                ]
              }
            ]
          }
        },
        "output": {
          "dashboard": {
            "panels": [
              {
                "targets": [
                  {
                    "expr": "sum((rate(foo)))TEST"
                  },
                  {
                    "expr": "avg(bar)"
                  }
                ]
              }
            ]
          }
        }
      }
    ],
    "identifier": 72467425
  },
  {
    "context": [
      "jq '. | (.dashboard.panels[].targets[].expr | select(contains(\"sum((rate(wmi\"))) += \") * on(instance, process_id) group_left(name, display_name, run_as) windows_service_info\\{display_name=~\\\"$variable\\\",job=\\\"$job\\\"\\})\"'",
      "You need to escape quotation marks inside a quoted string. And the initial .| is redundant:",
      "jq '(.dashboard.panels[].targets[].expr | select(contains(\"sum((rate(wmi\"))) += \") * on(instance, process_id) group_left(name, display_name, run_as) windows_service_info{display_name=~\\\"$variable\\\",job=\\\"$job\\\"})\"'"
    ],
    "utterance": "Append the string ') * on(instance, process_id) group_left(name, display_name, run_as) windows_service_info{display_name=~\"$variable\",job=\"$job\"})' to each expr field in dashboard.panels[].targets[] where expr contains 'sum((rate(wmi'.",
    "expressions": [
      "(.dashboard.panels[].targets[].expr | select(contains(\"sum((rate(wmi\"))) += \") * on(instance, process_id) group_left(name, display_name, run_as) windows_service_info{display_name=~\\\"$variable\\\",job=\\\"$job\\\"})\""
    ],
    "identifier": 72478087
  },
  {
    "context": [
      "I have the following JSON. From there I'd like to count how many objects I have which type attribute is either \"null\" or has an array that contains the value \"null\". In the following example, the answer would be two.",
      "jq '[.. | objects.type | select(strings == \"null\", IN(arrays[]; \"null\"))] | length'",
      "jq 'reduce (.. | objects.type | select(strings == \"null\", IN(arrays[]; \"null\"))) as $_ (0; .+1)'",
      "count(.. | objects | select(hasValue(\"null\")))"
    ],
    "utterance": "Count how many objects have a type attribute equal to \"null\" or a type array containing \"null\".",
    "expressions": [
      "[.. | objects.type | select(strings == \"null\", IN(arrays[]; \"null\"))] | length",
      "reduce (.. | objects.type | select(strings == \"null\", IN(arrays[]; \"null\"))) as $_ (0; .+1)",
      "def count(s): reduce s as $x (0; .+1); def hasValue($value): has(\"type\") and (.type | . == $value or (type == \"array\" and any(. == $value))); count(.. | objects | select(hasValue(\"null\")))"
    ],
    "data": [
      {
        "input": {
          "A": {
            "type": "string"
          },
          "B": {
            "type": "null"
          },
          "C": {
            "type": [
              "null",
              "string"
            ]
          }
        },
        "output": 2
      }
    ],
    "identifier": 72485378
  },
  {
    "context": [
      "I want to be able to quickly figure out how many Deployments in a namespace don't have a container named \"main\".",
      "This is as close as I have got so far, using jq, which gives me a list of all container names:",
      "The problem with that is, I can't see which containers belong to which Deployments."
    ],
    "utterance": "Count the number of Deployments in a namespace that do not have any container named 'main'.",
    "expressions": [
      ".items | map(select(.spec.template.spec.containers | all(.name != \"main\"))) | length"
    ],
    "identifier": 72520369
  },
  {
    "context": [
      "I have a JSON-array that I would like to write to the STDOUT with one element pr line such that our logging tool, Grafana, can more easily pick it up.",
      "What I need:",
      "{...}\n{...}",
      "Running `jq -c '.[]'` produces:",
      "{...}\n{...}"
    ],
    "utterance": "Output each element of an array as a compact object, one per line, to stdout.",
    "expressions": [
      "jq -c '.[]'"
    ],
    "data": [
      {
        "input": [
          {
            "PkgName": "perl-base",
            "Severity": "MEDIUM",
            "VulnerabilityID": "CVE-2020-16156",
            "InstalledVersion": "5.34.0-3ubuntu1",
            "FixedVersion": "",
            "Title": "perl-CPAN: Bypass of verification of signatures in CHECKSUMS files",
            "PrimaryURL": "https://avd.aquasec.com/nvd/cve-2020-16156",
            "namespace": "la",
            "image": ""
          },
          {
            "PkgName": "tar",
            "Severity": "LOW",
            "VulnerabilityID": "CVE-2019-9923",
            "InstalledVersion": "1.34+dfsg-1build3",
            "FixedVersion": "",
            "Title": "tar: null-pointer dereference in pax_decode_header in sparse.c",
            "PrimaryURL": "https://avd.aquasec.com/nvd/cve-2019-9923",
            "namespace": "la",
            "image": ""
          }
        ],
        "output": [
          "{\"PkgName\":\"perl-base\",\"Severity\":\"MEDIUM\",\"VulnerabilityID\":\"CVE-2020-16156\",\"InstalledVersion\":\"5.34.0-3ubuntu1\",\"FixedVersion\":\"\",\"Title\":\"perl-CPAN: Bypass of verification of signatures in CHECKSUMS files\",\"PrimaryURL\":\"https://avd.aquasec.com/nvd/cve-2020-16156\",\"namespace\":\"la\",\"image\":\"\"}",
          "{\"PkgName\":\"tar\",\"Severity\":\"LOW\",\"VulnerabilityID\":\"CVE-2019-9923\",\"InstalledVersion\":\"1.34+dfsg-1build3\",\"FixedVersion\":\"\",\"Title\":\"tar: null-pointer dereference in pax_decode_header in sparse.c\",\"PrimaryURL\":\"https://avd.aquasec.com/nvd/cve-2019-9923\",\"namespace\":\"la\",\"image\":\"\"}"
        ]
      }
    ],
    "identifier": 72488855
  },
  {
    "context": [
      "I have a need to merge two YAML files with YQ/JQ update only on the map file.",
      "The data & map are supposed to be changing.  Is there any way to achieve this in jq or yq?",
      "Expected outcome:",
      "data1:",
      "  subkey1: subvalue1",
      "  subkey2: subvalue2",
      "data3:",
      "  subkey3: subvalue3",
      "gojq -n --yaml-input --yaml-output '\n  input as $data\n  | input as $map\n  | reduce ($map | keys[]) as $k ({}; .[$k] = $data[$k])\n' data.yaml map.yaml",
      "gojq -n --yaml-input --yaml-output '\n  input as $data\n  | input as $map\n  | reduce ($map | tostream | select(length==2)) as [$k, $_] ({}; setpath($k; $data | getpath($k)) )\n' data.yaml map.yaml"
    ],
    "utterance": "Copy only the keys and subkeys present in the map file, replacing their values with those from the corresponding locations in the data file.",
    "expressions": [
      "input as $data | input as $map | reduce ($map | keys[]) as $k ({}; .[$k] = $data[$k])",
      "input as $data | input as $map | reduce ($map | tostream | select(length==2)) as [$k, $_] ({}; setpath($k; $data | getpath($k)) )"
    ],
    "data": [
      {
        "input": {
          "data.yaml": {
            "data1": {
              "subkey1": "subvalue1",
              "subkey2": "subvalue2"
            },
            "data2": "value2",
            "data3": {
              "subkey3": "subvalue3"
            }
          },
          "map.yaml": {
            "data1": {},
            "data3": {
              "subkey3": null
            }
          }
        },
        "output": {
          "data1": {
            "subkey1": "subvalue1",
            "subkey2": "subvalue2"
          },
          "data3": {
            "subkey3": "subvalue3"
          }
        }
      }
    ],
    "identifier": 72488570
  },
  {
    "context": [
      "I want to merge these two modules arrays.",
      "jq '.modules[]' base_dependency.txt",
      "base_modules=$(jq '.modules[]' base_dependencies.txt )"
    ],
    "utterance": "Extract the modules array from the file so it can be assigned to a variable for later merging with another modules array.",
    "expressions": [
      ".modules[]",
      ".modules"
    ],
    "data": [
      {
        "input": {
          "version": "1.0.1",
          "name": "test",
          "number": "1990",
          "buildAgent": {
            "name": "GENERIC",
            "version": "2.16.4"
          },
          "agent": {
            "name": "jfrog-cli-go",
            "version": "2.16.4"
          },
          "started": "2022-05-20T15:01:48.827-0500",
          "durationMillis": 0,
          "artifactoryPrincipal": "test",
          "modules": [
            {
              "properties": {},
              "type": "generic",
              "id": "test",
              "artifacts": [
                {
                  "type": "jar",
                  "sha1": "bef8dd3",
                  "sha256": "1c2ba8cb5369d",
                  "md5": "f60031d2a0ef13dd8505b61af90c1c44",
                  "name": "test-0-SNAPSHOT16.jar",
                  "path": "libs-release-local/libs7/test-0-SNAPSHOT16.jar"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "properties": {},
            "type": "generic",
            "id": "test",
            "artifacts": [
              {
                "type": "jar",
                "sha1": "bef8dd3",
                "sha256": "1c2ba8cb5369d",
                "md5": "f60031d2a0ef13dd8505b61af90c1c44",
                "name": "test-0-SNAPSHOT16.jar",
                "path": "libs-release-local/libs7/test-0-SNAPSHOT16.jar"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 72507808
  },
  {
    "context": [
      "aws glue create-job --profile $PROFILE --name $NAME --cli-input-json | jq '.Command.ScriptLocation = '\\\"$SCRIPT_LOCATION\\\"'' ./resources/config.json",
      "So your command should become:",
      "aws glue create-job --profile $PROFILE --name $NAME --cli-input-json \"$(jq '.Command.ScriptLocation = \"$SCRIPT_LOCATION\"' ./resources/config.json)\"",
      "or simplified with only double quotes:",
      "aws glue create-job --profile $PROFILE --name $NAME --cli-input-json \"$(jq \".Command.ScriptLocation = \\\"$SCRIPT_LOCATION\\\"\" ./resources/config.json)\"",
      "jq \".Command.ScriptLocation = \\\"$SCRIPT_LOCATION\\\"\" ./resources/config.json | aws glue create-job --profile $PROFILE --name $NAME --cli-input-json -",
      "jq \".Command.ScriptLocation = \\\"$SCRIPT_LOCATION\\\"\" ./resources/config.json > ./resources/config.replaced.json && aws glue create-job --profile $PROFILE --name $NAME --cli-input-json file://./resources/config.replaced.json"
    ],
    "utterance": "Replace the value of the .Command.ScriptLocation field with the contents of the $SCRIPT_LOCATION shell variable and use the modified data as input for a subsequent command.",
    "expressions": [
      ".Command.ScriptLocation = \"$SCRIPT_LOCATION\"",
      ".Command.ScriptLocation = \\\"$SCRIPT_LOCATION\\\""
    ],
    "data": [
      {
        "input": {
          "Description": "Template for Glue Job",
          "LogUri": "",
          "Role": "arn:aws:iam::11111111111:role/role",
          "ExecutionProperty": {
            "MaxConcurrentRuns": 1
          },
          "Command": {
            "Name": "glueetl",
            "ScriptLocation": "s3://bucket/scripts/script.py",
            "PythonVersion": "3"
          },
          "DefaultArguments": {
            "--TempDir": "s3://temp/admin/",
            "--job-bookmark-option": "job-bookmark-disable",
            "--enable-metrics": "",
            "--enable-glue-datacatalog": "",
            "--enable-continuous-cloudwatch-log": "",
            "--enable-spark-ui": "true",
            "--spark-event-logs-path": "s3://assets/sparkHistoryLogs/"
          },
          "NonOverridableArguments": {
            "KeyName": ""
          },
          "MaxRetries": 0,
          "AllocatedCapacity": 0,
          "Timeout": 2880,
          "MaxCapacity": 0,
          "Tags": {
            "KeyName": ""
          },
          "NotificationProperty": {
            "NotifyDelayAfter": 60
          },
          "GlueVersion": "3.0",
          "NumberOfWorkers": 2,
          "WorkerType": "G.1X"
        },
        "output": {
          "Description": "Template for Glue Job",
          "LogUri": "",
          "Role": "arn:aws:iam::11111111111:role/role",
          "ExecutionProperty": {
            "MaxConcurrentRuns": 1
          },
          "Command": {
            "Name": "glueetl",
            "ScriptLocation": "s3://bucket/scripts/$NAME.py",
            "PythonVersion": "3"
          },
          "DefaultArguments": {
            "--TempDir": "s3://temp/admin/",
            "--job-bookmark-option": "job-bookmark-disable",
            "--enable-metrics": "",
            "--enable-glue-datacatalog": "",
            "--enable-continuous-cloudwatch-log": "",
            "--enable-spark-ui": "true",
            "--spark-event-logs-path": "s3://assets/sparkHistoryLogs/"
          },
          "NonOverridableArguments": {
            "KeyName": ""
          },
          "MaxRetries": 0,
          "AllocatedCapacity": 0,
          "Timeout": 2880,
          "MaxCapacity": 0,
          "Tags": {
            "KeyName": ""
          },
          "NotificationProperty": {
            "NotifyDelayAfter": 60
          },
          "GlueVersion": "3.0",
          "NumberOfWorkers": 2,
          "WorkerType": "G.1X"
        }
      }
    ],
    "identifier": 72477518
  },
  {
    "context": [
      "Now I want to further filter the result on the `Headers` record, and would only need the fields of `Accept`, `User-Agent`, and `Referer`, and discard any other fields that might exist.",
      "Everything else should *remain the same* as the sample output.",
      "jq '( .. | objects | ( .QueryString, .Params ) | select(.) )\n         |= ( map( @uri \"\\( .Name )=\\( .Value )\" ) | join(\"&\") )\n    |\n    ( .. | objects | .Headers | select(.) )\n         |= map(select(.Name|IN(\"Accept\", \"Referer\", \"User-Agent\")))\n   '",
      "jq 'walk(\n      ( objects | ( .QueryString, .Params ) | select(.) )\n         |= ( map( @uri \"\\( .Name )=\\( .Value )\" ) | join(\"&\") )\n      |\n      ( objects | .Headers | select(.) )\n         |= map(select(.Name|IN(\"Accept\", \"Referer\", \"User-Agent\")))\n   )'"
    ],
    "utterance": "Transform Name/Value pairs under QueryString and Params, and filter Headers so that only entries where Name is Accept, User-Agent, or Referer are kept, leaving everything else unchanged.",
    "expressions": [
      "( .. | objects | ( .QueryString, .Params ) | select(.) )\n         |= ( map( @uri \"\\( .Name )=\\( .Value )\" ) | join(\"&\") )\n    |\n    ( .. | objects | .Headers | select(.) )\n         |= map(select(.Name|IN(\"Accept\", \"Referer\", \"User-Agent\")))",
      "walk(\n      ( objects | ( .QueryString, .Params ) | select(.) )\n         |= ( map( @uri \"\\( .Name )=\\( .Value )\" ) | join(\"&\") )\n      |\n      ( objects | .Headers | select(.) )\n         |= map(select(.Name|IN(\"Accept\", \"Referer\", \"User-Agent\")))\n   )"
    ],
    "identifier": 72510429
  },
  {
    "context": [
      "However, I\u0019m also not interested in the 3par devices. If I add to the query with:",
      "jq '. | select(.state!=\"ProfileApplied\") | .name | contains(\"3par\")|not'",
      "it gives me:\n\ntrue\nfalse\ntrue\n\nwhich is correct, but I really want the json object returned to match the \"true\" values. Does anyone know how I achieve that?",
      "Your idea was right. You need to move the second condition _inside_ the select statement to add a boolean AND logic.",
      "select((.state != \"ProfileApplied\") and (.name | contains(\"3par\") | not))"
    ],
    "utterance": "Return all objects where state is not ProfileApplied and name does not contain 3par.",
    "expressions": [
      "select((.state != \"ProfileApplied\") and (.name | contains(\"3par\") | not))"
    ],
    "data": [
      {
        "input": [
          {
            "name": "pp-site1-r1-n2",
            "state": "Monitored",
            "stateReason": "NotApplicable"
          },
          {
            "name": "bb-site2-3par-ilo",
            "state": "Monitored",
            "stateReason": "NotApplicable"
          },
          {
            "name": "tm-site1-r3-n4-ilo",
            "state": "ProfileError",
            "stateReason": "NotApplicable"
          },
          {
            "name": "tm-site3-r1-n6-ilo",
            "state": "ProfileApplied",
            "stateReason": "NotApplicable"
          }
        ],
        "output": [
          {
            "name": "pp-site1-r1-n2",
            "state": "Monitored",
            "stateReason": "NotApplicable"
          },
          {
            "name": "tm-site1-r3-n4-ilo",
            "state": "ProfileError",
            "stateReason": "NotApplicable"
          }
        ]
      }
    ],
    "identifier": 72519351
  },
  {
    "context": [
      "Pick out all the name/value pair under `.QueryString, .Params` into the same unnested array",
      "The output would be:\n[\n  {\n    \"Name\": \"IsOrdered\",\n    \"Value\": \"1\"\n  },\n  ...\n]",
      "without any empty arrays output (`[]`), while keep the repeated values in the array.",
      "And the final output need to be unnested into a single array too.",
      "Bonus Q: Would it be possible to output each name/value pair on one line of their own like the following?",
      "Although this expression can be simplified into `.. | objects | .QueryString[]?, .Params[]?`",
      "jq -c '.. | objects | select( .Name and .Value)'"
    ],
    "utterance": "Retrieve all objects with Name and Value keys found under any QueryString or Params property at any depth, combining them into a single flat list while excluding empty arrays and preserving duplicates.",
    "expressions": [
      "[(.. | objects | (.QueryString, .Params) | select(. != null and . != []))] | flatten",
      ".. | objects | .QueryString[]?, .Params[]?",
      ".. | objects | (.QueryString, .Params) | .. | objects | select(.Name and .Value)",
      ".. | objects | select(.Name and .Value)"
    ],
    "data": [
      {
        "input": {
          "Some": "Random stuff",
          "One": {
            "QueryString": [
              {
                "Name": "IsOrdered",
                "Value": "1"
              },
              {
                "Name": "TimeStamp",
                "Value": "11654116426247"
              }
            ]
          },
          "Two": {
            "QueryString": [
              {
                "Name": "IsOrdered",
                "Value": "1"
              },
              {
                "Name": "TimeStamp",
                "Value": "11654116426247"
              }
            ]
          },
          "Params": [
            {
              "Name": "ClassName",
              "Value": "PRODUCT"
            },
            {
              "Name": "ListID",
              "Value": "Products"
            },
            {
              "Name": "Mode ",
              "Value": "1"
            },
            {
              "Name": "Dept",
              "Value": "5"
            },
            {
              "Name": "HasPrevOrder",
              "Value": ""
            }
          ],
          "And": {
            "QueryString": []
          },
          "More": "like",
          "More+": "this"
        },
        "output": [
          {
            "Name": "IsOrdered",
            "Value": "1"
          },
          {
            "Name": "TimeStamp",
            "Value": "11654116426247"
          },
          {
            "Name": "IsOrdered",
            "Value": "1"
          },
          {
            "Name": "TimeStamp",
            "Value": "11654116426247"
          },
          {
            "Name": "ClassName",
            "Value": "PRODUCT"
          },
          {
            "Name": "ListID",
            "Value": "Products"
          },
          {
            "Name": "Mode ",
            "Value": "1"
          },
          {
            "Name": "Dept",
            "Value": "5"
          },
          {
            "Name": "HasPrevOrder",
            "Value": ""
          }
        ]
      }
    ],
    "identifier": 72500269
  },
  {
    "context": [
      "I need a jq query that will resolve to true in the first example where key \"blacklisted_library_found\" is *not* present and false in the second example where key blacklisted_library_found *is* present",
      "Use `has` to check for the presence of that key, in combination with `not` to invert the result:",
      "jq 'has(\"blacklisted_library_found\") | not'",
      "This produces `true` for the first example, and `false` for the second."
    ],
    "utterance": "Return true if the key blacklisted_library_found is not present in the input; return false if it is present.",
    "expressions": [
      "has(\"blacklisted_library_found\") | not"
    ],
    "data": [
      {
        "input": {
          "control": "library_blacklist",
          "policy_id": 13,
          "policy_name": "the-policy"
        },
        "output": true
      },
      {
        "input": {
          "blacklisted_library_found": [
            "library.dll"
          ],
          "control": "library_blacklist",
          "failed": true,
          "policy_id": 13,
          "policy_name": "the-policy"
        },
        "output": false
      }
    ],
    "identifier": 72528017
  },
  {
    "context": [
      "However how do I add multiple conditions to capture both conditions ?",
      ".image | match(\"(?<=\\\\/)(.*?)(?=\\\\:|\\\\@)\").captures[].string",
      ".image | match(\"(?<=/)(.*?)(?=:|@)\").captures[].string",
      ".image | match(\"/([^:@]+)\").captures[].string"
    ],
    "utterance": "Extract the image name that appears after the last slash and before either a colon or an at sign in an image string like 'docker/nginx:latest' or 'docker/nginx@sha256:9560f8528a3cd'.",
    "expressions": [
      ".image | match(\"(?<=/)(.*?)(?=:|@)\").captures[].string",
      ".image | match(\"/([^:@]+)\").captures[].string"
    ],
    "data": [
      {
        "input": {
          "image": "docker/nginx:latest"
        },
        "output": "nginx"
      },
      {
        "input": {
          "image": "docker/nginx@sha256:9560f8528a3cd"
        },
        "output": "nginx"
      }
    ],
    "identifier": 72543799
  },
  {
    "context": [
      "I Would also need to delete every resources that contains \"cdkpipelinePipeline\", before the Type block :",
      "You could use the following jq fragment in your pipeline:",
      "with_entries( select(.key|contains(\"cdkpipelinePipeline\")|not) )"
    ],
    "utterance": "Remove all resources whose keys contain the string 'cdkpipelinePipeline'.",
    "expressions": [
      "with_entries(select(.key|contains(\"cdkpipelinePipeline\")|not))"
    ],
    "data": [
      {
        "input": {
          "developcdkpipelinePipeline": {
            "Type": "AWS::CodePipeline::Pipeline",
            "Properties": {
              "RoleArn": {
                "Fn::GetAtt": [
                  "developcdkpipelinePipelineRole",
                  "Arn"
                ]
              }
            }
          },
          "developcdkpipelinePipelineRole": {
            "Type": "AWS::IAM::Role",
            "Properties": {
              "AssumeRolePolicyDocument": {
                "Statement": [
                  {
                    "Action": "sts:AssumeRole",
                    "Effect": "Allow",
                    "Principal": {
                      "Service": "codepipeline.amazonaws.com"
                    }
                  }
                ],
                "Version": "2012-10-17"
              },
              "Tags": [
                {
                  "Key": "Application",
                  "Value": "develop"
                }
              ]
            },
            "DependsOn": [
              "AuroraNestedStackAuroraNestedStackResource"
            ],
            "Metadata": {
              "aws:cdk:path": "develop-cicd-stack/develop-cdkpipeline/Pipeline/Role/Resource"
            }
          },
          "OtherResource": {
            "Type": "Some::Other::Resource",
            "Properties": {}
          }
        },
        "output": {
          "OtherResource": {
            "Type": "Some::Other::Resource",
            "Properties": {}
          }
        }
      }
    ],
    "identifier": 72532938
  },
  {
    "context": [
      "I have a data structure like this:",
      "[{\"some_id\": \"123\",\"items_1\": [{\"label\": \"my_name\"}],\"items_2\": []},{\"some_id\": \"123\",\"items_1\": [],\"items_2\": [\"value_1\",\"value_3\"]},{\"some_id\": \"123\",\"items_1\": [],\"items_2\": [\"value_1\",\"value_2\"]}]",
      "And I want to modify the data into something like",
      "[{\"some_id\": \"123\",\"items_1\": [{\"label\": \"my_name\"}],\"items_2\": [\"value_1\",\"value_2\",\"value_3\"]}]",
      "Basically taking any fields that are the same and concatenating the arrays together.",
      "Would the following work for you?\n\ngroup_by(.some_id) | map({\nsome_id: map(.some_id) | first,\nitems_1: map(.items_1) | add | unique,\nitems_2: map(.items_2) | add | unique })"
    ],
    "utterance": "Combine all entries with the same some_id by concatenating the arrays in their items_1 and items_2 fields, removing duplicates in the arrays.",
    "expressions": [
      "group_by(.some_id) | map({\n  some_id: map(.some_id) | first,\n  items_1: map(.items_1) | add | unique,\n  items_2: map(.items_2) | add | unique\n})"
    ],
    "data": [
      {
        "input": [
          {
            "some_id": "123",
            "items_1": [
              {
                "label": "my_name"
              }
            ],
            "items_2": []
          },
          {
            "some_id": "123",
            "items_1": [],
            "items_2": [
              "value_1",
              "value_3"
            ]
          },
          {
            "some_id": "123",
            "items_1": [],
            "items_2": [
              "value_1",
              "value_2"
            ]
          }
        ],
        "output": [
          {
            "some_id": "123",
            "items_1": [
              {
                "label": "my_name"
              }
            ],
            "items_2": [
              "value_1",
              "value_2",
              "value_3"
            ]
          }
        ]
      }
    ],
    "identifier": 72523173
  },
  {
    "context": [
      "However I also need to transform the keys, by adding a prefix of `**/`, so that I end up with:\n```\n{ \n  \"**/@example/alpha\" : \"1.2.3\",\n  \"**/@example/bravo\" : \"1.2.3\",\n  \"**/@example/charlie\" : \"1.2.3\"\n}\n```",
      "**How can I add the prefix to every key?**",
      "You can modify `.key` inside your `with_entries` just as you can filter on it:\n\n```\njq -r '\n  .dependencies\n  | select(. != null)\n  | with_entries(\n      select(.key | contains(\"@example\"))\n      | .key |= \"**/(.)\"\n    )' package.json\n```"
    ],
    "utterance": "Select all dependency keys containing '@example' and add a '**/' prefix to each key.",
    "expressions": [
      ".dependencies | select(. != null) | with_entries(select(.key | contains(\"@example\")) | .key |= \"**/(.)\")"
    ],
    "data": [
      {
        "input": {
          "name": "Example",
          "dependencies": {
            "@example/alpha": "1.2.3",
            "@example/bravo": "1.2.3",
            "@example/charlie": "1.2.3"
          }
        },
        "output": {
          "**/@example/alpha": "1.2.3",
          "**/@example/bravo": "1.2.3",
          "**/@example/charlie": "1.2.3"
        }
      }
    ],
    "identifier": 72535594
  },
  {
    "context": [
      "How can I modify the file to read like below, where only the file names stripped from sources url? Don&#39;t want to touch cloud value",
      "jq &#39;.sources[] |= ( split(&quot;/&quot;) | last )&#39;"
    ],
    "utterance": "Replace each entry in the sources array with only the filename from its URL, without changing other fields.",
    "expressions": [
      ".sources[] |= (split(\"/\") | last)"
    ],
    "data": [
      {
        "input": {
          "cloud": "https://cloudfronturl/folder/folder",
          "env": "int",
          "sources": [
            "https://www.example.com/some.tar.gz",
            "https://www.example2.com/folder1/folder2/another.tar.gz"
          ],
          "owner": "some manager"
        },
        "output": {
          "cloud": "https://cloudfronturl/folder/folder",
          "env": "int",
          "sources": [
            "some.tar.gz",
            "another.tar.gz"
          ],
          "owner": "some manager"
        }
      }
    ],
    "identifier": 72553653
  },
  {
    "context": [
      "What required is to filter the only elements that do not have certain keyword - \"red\" for instance.",
      "You can use `all` to give a condition all items must meet. Here, all values in `.tags[].id` must be unequal `!=` to `\"red\"`:\n~~~sh\njq '.data[] | select(all(.tags[].id; . != \"red\"))'\n~~~",
      "`.data[] | select([ .tags[].id ] | index(\"red\") | not)`"
    ],
    "utterance": "Return all objects whose 'tags' array does not contain an object with 'id' equal to 'red'.",
    "expressions": [
      ".data[] | select(all(.tags[].id; . != \"red\"))",
      ".data[] | select([ .tags[].id ] | index(\"red\") | not)",
      ".data[] | select([ .tags[].id ] | contains([\"red\"]) | not)"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "name": "banana",
              "tags": [
                {
                  "id": "yellow"
                },
                {
                  "id": "long"
                }
              ]
            },
            {
              "name": "apple",
              "tags": [
                {
                  "id": "red"
                },
                {
                  "id": "round"
                }
              ]
            },
            {
              "name": "orange",
              "tags": [
                {
                  "id": "orange"
                },
                {
                  "id": "round"
                },
                {
                  "id": "colored"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "name": "banana",
            "tags": [
              {
                "id": "yellow"
              },
              {
                "id": "long"
              }
            ]
          },
          {
            "name": "orange",
            "tags": [
              {
                "id": "orange"
              },
              {
                "id": "round"
              },
              {
                "id": "colored"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 72533054
  },
  {
    "context": [
      "Given the List:\n[\n    {\n        \"prop1\": \"prop11\",\n        \"prop2\": \"prop21\",\n        \"list\": [\"element1\", \"element2\", \"element3\"]\n    },\n    {\n        \"prop1\": \"prop12\",\n        \"prop2\": \"prop22\",\n        \"list\": [\"element1\", \"element3\"]\n    },\n    {\n        \"prop1\": \"prop13\",\n        \"prop2\": \"prop23\",\n        \"list\": [\"element2\", \"element3\"]\n    }\n]\n\nWhile using jq, how to filter only the root's list elements by the children's lists.\nFor example, return all elements whose list contains element1.",
      "Check if `any` of the list's element equals `==` the given string:\n~~~sh\njq 'map(select(any(.list[]; . == \"element1\")))'\n~~~",
      "Use `.[] | \u2026` instead of `map(\u2026)` to get rid of the outer array:\n~~~sh\njq '.[] | select(any(.list[]; . == \"element1\"))'\n~~~",
      "`index` makes for a short and in practice quite fast solution:\n\n```\njq 'map(select(.list|index(\"element1\")))'\n```\n\nor\n```\njq -c '.[] | select(.list|index(\"element1\"))'\n```\n"
    ],
    "utterance": "Return all items where the list contains element1.",
    "expressions": [
      "map(select(any(.list[]; . == \"element1\")))",
      ".[] | select(any(.list[]; . == \"element1\"))",
      "map(select(.list|index(\"element1\")))",
      ".[] | select(.list|index(\"element1\"))"
    ],
    "data": [
      {
        "input": [
          {
            "prop1": "prop11",
            "prop2": "prop21",
            "list": [
              "element1",
              "element2",
              "element3"
            ]
          },
          {
            "prop1": "prop12",
            "prop2": "prop22",
            "list": [
              "element1",
              "element3"
            ]
          },
          {
            "prop1": "prop13",
            "prop2": "prop23",
            "list": [
              "element2",
              "element3"
            ]
          }
        ],
        "output": [
          {
            "prop1": "prop11",
            "prop2": "prop21",
            "list": [
              "element1",
              "element2",
              "element3"
            ]
          },
          {
            "prop1": "prop12",
            "prop2": "prop22",
            "list": [
              "element1",
              "element3"
            ]
          }
        ]
      }
    ],
    "identifier": 72536963
  },
  {
    "context": [
      "Only get the \"title\" and \"updated_at\" fields from the top level.",
      "Only get fields with keys = \"usernamevalue\" and \"passwordvalue\" from the subordinate \"fields\" array, and move those fields to the top level.",
      "jq 'map({id, updated_at} + (.fields | add | {usernamevalue, passwordvalue}))'"
    ],
    "utterance": "For each item, produce a flat object with only the title and updated_at fields from the top level, and the usernamevalue and passwordvalue fields extracted from the fields array.",
    "expressions": [
      "map({title, updated_at} + (.fields | add | {usernamevalue, passwordvalue}))"
    ],
    "data": [
      {
        "input": [
          {
            "id": "xxxx",
            "title": "xxxx",
            "created_at": "xxxx",
            "updated_at": "xxxx",
            "fields": [
              {
                "usernamevalue": "xxxx",
                "reference": "xxxx"
              },
              {
                "passwordvalue": "xxxx",
                "reference": "xxxx"
              },
              {
                "otherlabel": "xxxx",
                "otherreference": "xxxx"
              }
            ]
          },
          {
            "id": "xxxx",
            "title": "xxxx",
            "created_at": "xxxx",
            "updated_at": "xxxx",
            "fields": [
              {
                "usernamevalue": "xxxx",
                "reference": "xxxx"
              },
              {
                "passwordvalue": "xxxx",
                "reference": "xxxx"
              },
              {
                "otherlabel": "xxxx",
                "otherreference": "xxxx"
              }
            ]
          }
        ],
        "output": [
          {
            "title": "xxxx",
            "updated_at": "xxxx",
            "usernamevalue": "xxxx",
            "passwordvalue": "xxxx"
          },
          {
            "title": "xxxx",
            "updated_at": "xxxx",
            "usernamevalue": "xxxx",
            "passwordvalue": "xxxx"
          }
        ]
      }
    ],
    "identifier": 72560678
  },
  {
    "context": [
      "I'm trying to prune nodes deeply within a JSON structure and I'm puzzled why `empty` behaves seemingly different from a normal value here.",
      "# Expected output\n\nThe output I get, except without the `baz.1` child, as that one doesn't have a color.",
      ".[].children |= map(select(.color))",
      "In this case you can use `del` instead:\n```\ndel(.[].children[] | select(has(\"color\") | not))\n```"
    ],
    "utterance": "Remove all children objects from each parent that do not have a color property.",
    "expressions": [
      ".[].children |= map(select(.color))",
      "del(.[].children[] | select(has(\"color\") | not))"
    ],
    "data": [
      {
        "input": [
          {
            "name": "foo",
            "children": [
              {
                "name": "foo.0",
                "color": "red"
              }
            ]
          },
          {
            "name": "bar",
            "children": [
              {
                "name": "bar.0",
                "color": "green"
              },
              {
                "name": "bar.1"
              }
            ]
          },
          {
            "name": "baz",
            "children": [
              {
                "name": "baz.0"
              },
              {
                "name": "baz.1"
              }
            ]
          }
        ],
        "output": [
          {
            "name": "foo",
            "children": [
              {
                "name": "foo.0",
                "color": "red"
              }
            ]
          },
          {
            "name": "bar",
            "children": [
              {
                "name": "bar.0",
                "color": "green"
              }
            ]
          },
          {
            "name": "baz",
            "children": []
          }
        ]
      }
    ],
    "identifier": 72561279
  },
  {
    "context": [
      "You can compare to the empty object `{}`, so `. == {}` or `. != {}` produce a boolean, which should do what you want.",
      "if jq -e '. == {}' <\"$dups\" >/dev/null",
      "jq '\n  if . == {} then error(\"empty document found\") else . end\n  | ...rest of your processing here...\n'",
      "if . == {} then empty else . end"
    ],
    "utterance": "Determine whether an object is empty by evaluating if it is equal to {}.",
    "expressions": [
      ". == {}",
      "if . == {} then error(\"empty document found\") else . end",
      "if . == {} then empty else . end"
    ],
    "data": [
      {
        "input": {},
        "output": true
      },
      {
        "input": {
          "Basket1": [
            "Apple",
            "Orange"
          ]
        },
        "output": false
      }
    ],
    "identifier": 72563252
  },
  {
    "context": [
      "I am trying to get the current `dependencies` and `devDependencies` versions that are set in the package.json file so that when the MakeFile is run for a new user, it installs the versions listed there and not just the latest version.",
      "So for the example below, instead of just saying `npm install @applitools/eyes-testcafe` we would grab the version `1.16.1` from the package.json and interpolate it there in the MakeFile like `${eyes_version}` or something like that.",
      "Since you are using `jq`, \r\n```\r\njq '.devDependencies[\"@applitools/eyes-testcafe\"]' package.json\r\n```"
    ],
    "utterance": "Retrieve the version string for '@applitools/eyes-testcafe' listed under devDependencies.",
    "expressions": [
      ".devDependencies[\"@applitools/eyes-testcafe\"]"
    ],
    "data": [
      {
        "input": {
          "devDependencies": {
            "@applitools/eyes-testcafe": "^1.16.1",
            "testcafe": "^1.18.6",
            "testcafe-reporter-xunit": "*"
          }
        },
        "output": "^1.16.1"
      }
    ],
    "identifier": 72564278
  },
  {
    "context": [
      "Is there a way in jq to go from this stdout:\r\n```\r\nThu Jun 9 10:09:14 AM EDT 2022IP86.75.30.9\r\n```\r\nto this?:\r\n```\r\n{\r\n\t\"date\": \"Thu Jun 9 10:09:14 AM EDT 2022\",\r\n\t\"ip\": \"86.75.30.9\"\r\n}\r\n```\r\n",
      "split(\"IP\") | { date: .[0], ip: .[1] }",
      "jq -R 'capture(\"(?<date>.*)IP(?<ip>.*)\")'"
    ],
    "utterance": "Extract the date and IP address from a single line, assigning them as values to keys 'date' and 'ip' respectively, where the line contains a date string followed immediately by the literal 'IP' and then the IP address.",
    "expressions": [
      "split(\"IP\") | { date: .[0], ip: .[1] }",
      "capture(\"(?<date>.*)IP(?<ip>.*)\")"
    ],
    "data": [
      {
        "input": "Thu Jun 9 10:09:14 AM EDT 2022IP86.75.30.9",
        "output": {
          "date": "Thu Jun 9 10:09:14 AM EDT 2022",
          "ip": "86.75.30.9"
        }
      }
    ],
    "identifier": 72562169
  },
  {
    "context": [
      "I want to extract a ranking from a list of elements inside a json object whose order shows the position of the item in the respective category.",
      "I have a file with these 2 samples ...",
      "and want as output:",
      "{ \"a\":\"Ubain Solt\", \"r\":0, \"c\":\"triathlon\"}",
      "{ \"a\":\"Jon Snow\", \"r\":1, \"c\":\"triathlon\"}",
      "{ \"a\": \"Mickey Mouse\", \"r\":2, \"c\":\"triathlon\"}",
      "{ \"a\": \"Picheal Phelms\", \"r\":0, \"c\":\"swimming\"}",
      "{ \"a\": \"Lacky Kedetie\", \"r\":1, \"c\":\"swimming\"}",
      "jq -s '.[] | .category as $c | .athletes_list | to_entries[] | ({ a: .value.athlete_name, r: .key, c: $c })' triathlon swimming",
      "The 'trick' is to use `to_entries` so we can use `.key` as the 'index'."
    ],
    "utterance": "For each athlete, output an object with their name, their index in the category's athletes_list as 'r', and the category name as 'c'.",
    "expressions": [
      ". as [$first, $second] | [$first, $second] | .[] | .category as $c | .athletes_list | to_entries[] | { a: .value.athlete_name, r: .key, c: $c }",
      ".[] | .category as $c | .athletes_list | to_entries[] | { a: .value.athlete_name, r: .key, c: $c }",
      "jq -s '.[] | .category as $c | .athletes_list | to_entries[] | ({ a: .value.athlete_name, r: .key, c: $c })'"
    ],
    "data": [
      {
        "input": [
          {
            "category": "triathlon",
            "athletes_list": [
              {
                "athlete_name": "Ubain Solt"
              },
              {
                "athlete_name": "Jon Snow"
              },
              {
                "athlete_name": "Mickey Mouse"
              }
            ]
          },
          {
            "category": "swimming",
            "athletes_list": [
              {
                "athlete_name": "Picheal Phelms"
              },
              {
                "athlete_name": "Lacky Kedetie"
              }
            ]
          }
        ],
        "output": [
          {
            "a": "Ubain Solt",
            "r": 0,
            "c": "triathlon"
          },
          {
            "a": "Jon Snow",
            "r": 1,
            "c": "triathlon"
          },
          {
            "a": "Mickey Mouse",
            "r": 2,
            "c": "triathlon"
          },
          {
            "a": "Picheal Phelms",
            "r": 0,
            "c": "swimming"
          },
          {
            "a": "Lacky Kedetie",
            "r": 1,
            "c": "swimming"
          }
        ]
      }
    ],
    "identifier": 72559679
  },
  {
    "context": [
      "I'm using jq to try and merge 2 json files into one unique file.",
      "If I switch order of files I either end up losing 'actors' from file1 or 'year' from file2.",
      "How it should work:\n- the elements in file 2 will be leading and should replace the matching elements in file 1.\n- the elements in file 1 that doesn't exist in file 2 (like writer and movies[].actors elements) shouldn't be deleted\n- the elements in file 2 that doesn't exist yet in file 1 will be added (like producer and movies[].year).\n- a title is unique and should by default not occur more then once, but if it does remove the duplicates.",
      "In a comment you state\n> `.movies[0]` always correspond to the same movie in both files",
      "This enables you to use `transpose` to align the items from both arrays, and then apply object-merging on each pair of corresponding items.",
      "Here's a solution using plain `add` for the merging of the array items as well as of the other top-level fields:\n\n~~~sh\njq -s 'add + {movies: map(.movies) | transpose | map(add)}' file1 file2\n~~~",
      "~~~json\n{\n  \"series\": \"Harry Potter Movie Series\",\n  \"writer\": \"J.K. Rowling\",\n  \"movies\": [\n    {\n      \"title\": \"Harry Potter and the Philosopher's Stone\",\n      \"actors\": [\n        {\n          \"names\": [\n            \"Emma Watson\",\n            \"Other actor\"\n          ],\n          \"other\": \"Some value\"\n        }\n      ],\n      \"year\": \"2001\"\n    },\n    {\n      \"title\": \"Harry Potter and the Chamber of Secrets\",\n      \"actors\": [\n        {\n          \"names\": [\n            \"Emma Watson\"\n          ],\n          \"other\": \"Some value\"\n        }\n      ],\n      \"year\": \"2002\"\n    }\n  ],\n  \"producer\": \"David Heyman\"\n}\n~~~"
    ],
    "utterance": "Merge two files so that corresponding objects in the 'movies' arrays are merged by title, keeping all unique fields, with file 2 values taking precedence when overlapping, and all other fields from both files are also preserved.",
    "expressions": [
      "jq -s 'add + {movies: map(.movies) | transpose | map(add)}' file1 file2"
    ],
    "data": [
      {
        "input": [
          {
            "series": "Harry Potter Movie Series",
            "writer": "J.K. Rowling",
            "movies": [
              {
                "title": "Harry Potter and the Philosopher's Stone",
                "actors": [
                  {
                    "names": [
                      "Emma Watson",
                      "Other actor"
                    ],
                    "other": "Some value"
                  }
                ]
              },
              {
                "title": "Harry Potter and the Chamber of Secrets",
                "actors": [
                  {
                    "names": [
                      "Emma Watson"
                    ],
                    "other": "Some value"
                  }
                ]
              }
            ]
          },
          {
            "series": "Harry Potter Movie Series",
            "producer": "David Heyman",
            "movies": [
              {
                "title": "Harry Potter and the Philosopher's Stone",
                "year": "2001"
              },
              {
                "title": "Harry Potter and the Chamber of Secrets",
                "year": "2002"
              }
            ]
          }
        ],
        "output": {
          "series": "Harry Potter Movie Series",
          "writer": "J.K. Rowling",
          "movies": [
            {
              "title": "Harry Potter and the Philosopher's Stone",
              "actors": [
                {
                  "names": [
                    "Emma Watson",
                    "Other actor"
                  ],
                  "other": "Some value"
                }
              ],
              "year": "2001"
            },
            {
              "title": "Harry Potter and the Chamber of Secrets",
              "actors": [
                {
                  "names": [
                    "Emma Watson"
                  ],
                  "other": "Some value"
                }
              ],
              "year": "2002"
            }
          ],
          "producer": "David Heyman"
        }
      }
    ],
    "identifier": 72560468
  },
  {
    "context": [
      "What is the most computationally efficient way to lookup and add `root_id` attribute to those objects that have `parent_id` set?",
      "E.g. desired output for the above input would be:\n\n    {\n      \"id\": \"123456789012345\",\n      \"parent_id\": \"123456789012344\"\n      \"root_id\": \"123456789012344\"\n    }\n    {\n      \"id\": \"123456789012346\",\n      \"parent_id\": \"123456789012345\",\n      \"root_id\": \"123456789012344\"\n    }\n    {\n      \"id\": \"123456789012344\",\n      \"root_id\": \"123456789012344\"\n    }",
      "The following is fairly efficient, and for the given input produces the desired result,\nbut the requirements are unclear so please do not use the following blindly.",
      "The following assumes that jq is invoked with the -n command-line option.",
      "def origin_id($dict):\n  .parent_id as $p\n  | if $p == null then .id\n    elif .origin_id then .origin_id\n    else $dict[.parent_id] | origin_id($dict)\n    end;",
      "INDEX(inputs| if .parent_id == null then .origin_id=.id else . end; .id) as $ids\n| $ids[]\n| .origin_id = origin_id($ids)"
    ],
    "utterance": "For each object, add a root_id attribute set to the id of its ultimate ancestor (the root of its parent chain), or to its own id if it has no parent.",
    "expressions": [
      "def origin_id($dict):\n  .parent_id as $p\n  | if $p == null then .id\n    elif .origin_id then .origin_id\n    else $dict[.parent_id] | origin_id($dict)\n    end;\n    \nINDEX(inputs| if .parent_id == null then .origin_id=.id else . end; .id) as $ids\n| $ids[]\n| .origin_id = origin_id($ids)"
    ],
    "data": [
      {
        "input": [
          {
            "id": "123456789012345",
            "parent_id": "123456789012344"
          },
          {
            "id": "123456789012346",
            "parent_id": "123456789012345"
          },
          {
            "id": "123456789012344"
          }
        ],
        "output": [
          {
            "id": "123456789012345",
            "parent_id": "123456789012344",
            "root_id": "123456789012344"
          },
          {
            "id": "123456789012346",
            "parent_id": "123456789012345",
            "root_id": "123456789012344"
          },
          {
            "id": "123456789012344",
            "root_id": "123456789012344"
          }
        ]
      }
    ],
    "identifier": 72561553
  },
  {
    "context": [
      "I have two JSON object arrays:",
      "[{\"foo\": \"foo1\"}, {\"foo\": \"foo2\"}]",
      "[{\"bar\": \"bar1\"}, {\"bar\": \"bar2\"}, {\"bar\": \"bar3\"}, {\"bar\": \"bar4\"}]",
      "I would like to combine these into one array of objects which would end up looking like this:",
      "[{\"foo\": \"foo1\", \"bar\": \"bar1\"}, {\"foo\": \"foo1\", \"bar\": \"bar2\"}, ...]",
      "You can just use `+` on each item of both arrays. Assuming the two arrays are stored in variables `$a` and `$b`, then it'd be:",
      "jq '[$a[] + $b[]]'"
    ],
    "utterance": "Produce all possible combinations of objects from two arrays, merging each object from the first array with each object from the second array.",
    "expressions": [
      "[$a[] + $b[]]"
    ],
    "data": [
      {
        "input": {
          "a": [
            {
              "foo": "foo1"
            },
            {
              "foo": "foo2"
            }
          ],
          "b": [
            {
              "bar": "bar1"
            },
            {
              "bar": "bar2"
            },
            {
              "bar": "bar3"
            },
            {
              "bar": "bar4"
            }
          ]
        },
        "output": [
          {
            "foo": "foo1",
            "bar": "bar1"
          },
          {
            "foo": "foo1",
            "bar": "bar2"
          },
          {
            "foo": "foo1",
            "bar": "bar3"
          },
          {
            "foo": "foo1",
            "bar": "bar4"
          },
          {
            "foo": "foo2",
            "bar": "bar1"
          },
          {
            "foo": "foo2",
            "bar": "bar2"
          },
          {
            "foo": "foo2",
            "bar": "bar3"
          },
          {
            "foo": "foo2",
            "bar": "bar4"
          }
        ]
      }
    ],
    "identifier": 72573945
  },
  {
    "context": [
      "I have the following jq commands I want to run for each JSON object in an array that I'm processing:",
      "The output should appear as: MessageId, date-time, filelocation-key",
      "This is sample JSON:",
      "[ { \"Messages\": [ { \"MessageId\": \"3ee11508-b7d0-4116-aed4-8c4abe399fd4\", \"Body\": \"{\\\"key\\\":\\\"tmp/20220607_015010_163546.pgp\\\",\\\"eTag\\\":\\\"506f370e6a184b38ae4ad9988e396384\\\",\\\"versionId\\\":null}\", \"Attributes\": { \"SentTimestamp\": \"1654581487500\" } } ] }, { \"Messages\": [ { \"MessageId\": \"3ee11508-b7d0-4116-aed4-8c4abe399fd7\", \"Body\": \"{\\\"key\\\":\\\"tmp/20220607_015010_163547.pgp\\\",\\\"eTag\\\":\\\"506f370e6a184b38ae4ad9988e396384\\\",\\\"versionId\\\":null}\", \"Attributes\": { \"SentTimestamp\": \"1654581487700\" } } ] } ]",
      "Create an array with those 3 *filters*, then pass it on to `join(\", \")` \\ (or `@csv` if you don't need those spaces)",
      ".[].Messages[] | [ .MessageId,  (.Attributes.SentTimestamp | tonumber / 1000 | strftime(\"%Y-%m-%dT%H:%M:%S %Z\")), (.Body | fromjson | .eTag) ] | join(\", \")"
    ],
    "utterance": "For each message in all arrays, extract the MessageId, convert SentTimestamp to a human-readable UTC datetime, and retrieve the eTag from the JSON-parsed Body, outputting them as comma-separated values.",
    "expressions": [
      ".[].Messages[] | [ .MessageId,  (.Attributes.SentTimestamp | tonumber / 1000 | strftime(\"%Y-%m-%dT%H:%M:%S %Z\")), (.Body | fromjson | .eTag) ] | join(\", \")"
    ],
    "data": [
      {
        "input": [
          {
            "Messages": [
              {
                "MessageId": "3ee11508-b7d0-4116-aed4-8c4abe399fd4",
                "Body": "{\"key\":\"tmp/20220607_015010_163546.pgp\",\"eTag\":\"506f370e6a184b38ae4ad9988e396384\",\"versionId\":null}",
                "Attributes": {
                  "SentTimestamp": "1654581487500"
                }
              }
            ]
          },
          {
            "Messages": [
              {
                "MessageId": "3ee11508-b7d0-4116-aed4-8c4abe399fd7",
                "Body": "{\"key\":\"tmp/20220607_015010_163547.pgp\",\"eTag\":\"506f370e6a184b38ae4ad9988e396384\",\"versionId\":null}",
                "Attributes": {
                  "SentTimestamp": "1654581487700"
                }
              }
            ]
          }
        ],
        "output": [
          "3ee11508-b7d0-4116-aed4-8c4abe399fd4, 2022-06-07T05:58:07 UTC, 506f370e6a184b38ae4ad9988e396384",
          "3ee11508-b7d0-4116-aed4-8c4abe399fd7, 2022-06-07T05:58:07 UTC, 506f370e6a184b38ae4ad9988e396384"
        ]
      }
    ],
    "identifier": 72567396
  }
]