[
  {
    "context": [
      "Instead of always giving the `--indent n` flag on the command line, I would like to specify this in a config file (or library or module file \u2013 I&#39;m not sure what the correct terminology is).",
      "I tried putting various things in `~/.jq`, such as `indent: 4` or `--indent 4`, but they always gave me a compile error when I invoked `jq`.",
      "The `~/.jq` file contains jq code such as function definitions. It&#39;s not a config file in the classical sense.",
      "Most shells support aliases and you could set one yourself, e.g. in `~/.profile` or `~/.bashrc`/`~/.bash_aliases` with:",
      "alias jq='jq --indent 4'"
    ],
    "utterance": "Always use an indent level of 4 by default without specifying the option each time.",
    "expressions": [
      "alias jq='jq --indent 4'"
    ],
    "identifier": 75483011
  },
  {
    "context": [
      "My desired result is an array containing all the entrise of the first dictionary which are not part of the second one (equivalent to what the DISTINCT operator would do in SQL). So the expected output would be:\n\n```json\n[ \n  { key1: \"foo\", key2: \"baz\"},\n  { key1: \"bla\", key2: \"blubb\"},\n]\n```",
      "If you use `-s` (slurp), you can use `object1 - object2` to get the difference between them:\n```\njq -s  '.[0] - .[1]' a b\n```\n\nWill output:\n```json\n[\n  {\n    \"key1\": \"foo\",\n    \"key2\": \"baz\"\n  },\n  {\n    \"key1\": \"bla\",\n    \"key2\": \"blubb\"\n  }\n]\n```"
    ],
    "utterance": "Find all objects in the first file that do not occur in the second file.",
    "expressions": [
      ".[0] - .[1]"
    ],
    "data": [
      {
        "input": [
          [
            {
              "key1": "foo",
              "key2": "bar"
            },
            {
              "key1": "foo",
              "key2": "baz"
            },
            {
              "key1": "bla",
              "key2": "blubb"
            }
          ],
          [
            {
              "key1": "foo",
              "key2": "bar"
            },
            {
              "key1": "foo",
              "key2": "oof"
            },
            {
              "key1": "bla",
              "key2": "bla"
            }
          ]
        ],
        "output": [
          {
            "key1": "foo",
            "key2": "baz"
          },
          {
            "key1": "bla",
            "key2": "blubb"
          }
        ]
      }
    ],
    "identifier": 75486047
  },
  {
    "context": [
      "How does one create the CSV with only the \"name\" and \"version\" fields?",
      "If you know the two column names anyway, you could simply extract them directly using `.name` and `.version`:",
      "<file jq -r '[\"name\", \"version\"], (.[] | [.name, .version]) | @csv'",
      "You can also use your `$cols` variable, so the names only appear once:",
      "<file jq -r '[\"name\", \"version\"] as $cols | $cols, (.[] | [.[$cols[]]]) | @csv'",
      "Or import them dynamically, e.g. using `--args`:",
      "<file jq -r '$ARGS.positional, (.[] | [.[$ARGS.positional[]]]) | @csv' \\",
      "  --args name version",
      "Output:",
      "\"name\",\"version\"",
      "\"foo\",\"1.24\"",
      "\"bar\",\"1.21\"",
      "\"boo\",\"1.23\"",
      "\"far\",\"1.24\""
    ],
    "utterance": "Output a CSV with only the fields 'name' and 'version', each row representing an object.",
    "expressions": [
      "[\"name\", \"version\"], (.[] | [.name, .version]) | @csv",
      "[\"name\", \"version\"] as $cols | $cols, (.[] | [.[$cols[]]]) | @csv",
      "$ARGS.positional, (.[] | [.[$ARGS.positional[]]]) | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "name": "foo",
            "env": "dev",
            "version": "1.24"
          },
          {
            "name": "bar",
            "env": "staging",
            "version": "1.21"
          },
          {
            "name": "boo",
            "env": "prod",
            "version": "1.23"
          },
          {
            "name": "far",
            "env": "prod",
            "version": "1.24"
          }
        ],
        "output": [
          "\"name\",\"version\"",
          "\"foo\",\"1.24\"",
          "\"bar\",\"1.21\"",
          "\"boo\",\"1.23\"",
          "\"far\",\"1.24\""
        ]
      }
    ],
    "identifier": 75486489
  },
  {
    "context": [
      "I want to get the first array element from the first field. So I was expecting this:",
      "{\n    \"field1\": [\n        {\n            \"a\": \"F1A1\",\n            \"b\": \"F1B1\"\n        }\n    ],\n\n}",
      "To filter for certain items use `select`:",
      "jq '{field1} | map_values(map(select(.a == \"F1A1\" or .a == \"F1A4\")))'",
      "{\n  \"field1\": [\n    {\n      \"a\": \"F1A1\",\n      \"b\": \"F1B1\"\n    },\n    {\n      \"a\": \"F1A4\",\n      \"b\": \"F1B4\"\n    }\n  ]\n}"
    ],
    "utterance": "Extract only field1 and include in its array only elements where a is \"F1A1\" or \"F1A4\".",
    "expressions": [
      "{field1} | map_values(map(select(.a == \"F1A1\" or .a == \"F1A4\")))"
    ],
    "data": [
      {
        "input": {
          "field1": [
            {
              "a": "F1A1",
              "b": "F1B1"
            },
            {
              "a": "F1A2",
              "b": "F1B2"
            },
            {
              "a": "F1A3",
              "b": "F1B3"
            },
            {
              "a": "F1A4",
              "b": "F1B4"
            }
          ],
          "field2": [
            {
              "a": "F2A1",
              "b": "F2B1"
            },
            {
              "a": "F2A2",
              "b": "F2B2"
            }
          ],
          "field3": [
            {
              "a": "F3A1",
              "b": "F3B1"
            },
            {
              "a": "F3A2",
              "b": "F3B2"
            }
          ]
        },
        "output": {
          "field1": [
            {
              "a": "F1A1",
              "b": "F1B1"
            },
            {
              "a": "F1A4",
              "b": "F1B4"
            }
          ]
        }
      }
    ],
    "identifier": 75495172
  },
  {
    "context": [
      "Need to filter only those rows which is between year 2022 and 2030",
      "A simple solution could be to get the first `4` chars from your `DateTime`, convert that [`tonumber`][1] and use that as your `$year`",
      "Then [`select()`][2] all those where `$year > 2022 and $year < 2030`:",
      "map((.DateTime[0:4] | tonumber) as $year | select($year > 2022 and $year < 2030))",
      "A more complex solution, where we *correctly* parse the date:",
      "map(.DateTime | (sub(\"(?<time>.*)\\\\.[\\\\d]{3}(?<tz>.*)\"; \"\\(.time)\\(.tz)\") | fromdateiso8601 |  strftime(\"%Y\") | tonumber) as $year | select($year > 2022 and $year < 2030))"
    ],
    "utterance": "Filter all objects where the DateTime year is greater than 2022 and less than 2030.",
    "expressions": [
      "map((.DateTime[0:4] | tonumber) as $year | select($year > 2022 and $year < 2030))",
      "map(.DateTime | (sub(\"(?<time>.*)\\\\.[\\\\d]{3}(?<tz>.*)\"; \"\\(.time)\\(.tz)\") | fromdateiso8601 |  strftime(\"%Y\") | tonumber) as $year | select($year > 2022 and $year < 2030))"
    ],
    "data": [
      {
        "input": [
          {
            "DateTime": "2022-12-09T16:00:00.000Z",
            "Name": "name1"
          },
          {
            "DateTime": "2023-12-09T16:00:00.000Z",
            "Name": "name2"
          },
          {
            "DateTime": "2028-12-09T16:00:00.000Z",
            "Name": "name3"
          },
          {
            "DateTime": "2030-12-09T16:00:00.000Z",
            "Name": "name4"
          }
        ],
        "output": [
          {
            "DateTime": "2023-12-09T16:00:00.000Z",
            "Name": "name2"
          },
          {
            "DateTime": "2028-12-09T16:00:00.000Z",
            "Name": "name3"
          }
        ]
      }
    ],
    "identifier": 75508541
  },
  {
    "context": [
      "Trying to get unique entries from nested JSON arrays.",
      "Current Output (CSV",
      "One,1",
      "Two,2",
      "Two,2",
      "Three,3",
      "Four,4",
      "Five,5",
      "Desired Output (CSV)",
      "One,1",
      "Two,2",
      "Three,3",
      "Four,4",
      "Five,5",
      "jq -r 'map(.SIR[].PMD[].MMA[]) | unique[] | [.DN, .SA] | @csv'",
      "jq -r 'map(.SIR[].PMD[].MMA[]) | unique_by(.DN)[] | [.DN, .SA] | @csv'",
      "jq -r 'map(.SIR[].PMD[].MMA[]) | unique_by(.SA|tonumber)[] | [.DN, .SA] | @csv'",
      "jq -r 'map(.SIR[].PMD[].MMA[]) | unique_by([(.SA|tonumber), .DN])[] | [.DN, .SA] | @csv'"
    ],
    "utterance": "Extract all unique objects based on both fields DN and SA from all nested MMA arrays and output DN and SA as CSV rows.",
    "expressions": [
      "map(.SIR[].PMD[].MMA[]) | unique[] | [.DN, .SA] | @csv",
      "map(.SIR[].PMD[].MMA[]) | unique_by([(.SA|tonumber), .DN])[] | [.DN, .SA] | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "SIR": [
              {
                "PMD": [
                  {
                    "MMA": [
                      {
                        "DN": "One",
                        "SA": "1"
                      },
                      {
                        "DN": "Two",
                        "SA": "2"
                      }
                    ]
                  }
                ]
              }
            ]
          },
          {
            "SIR": [
              {
                "PMD": [
                  {
                    "MMA": [
                      {
                        "DN": "Two",
                        "SA": "2"
                      },
                      {
                        "DN": "Four",
                        "SA": "4"
                      }
                    ]
                  }
                ]
              }
            ]
          },
          {
            "SIR": [
              {
                "PMD": [
                  {
                    "MMA": [
                      {
                        "DN": "Three",
                        "SA": "3"
                      },
                      {
                        "DN": "Five",
                        "SA": "5"
                      }
                    ]
                  }
                ]
              }
            ]
          }
        ],
        "output": [
          "\"One\",\"1\"",
          "\"Two\",\"2\"",
          "\"Three\",\"3\"",
          "\"Four\",\"4\"",
          "\"Five\",\"5\""
        ]
      }
    ],
    "identifier": 75494790
  },
  {
    "context": [
      "I want to remove everything between each pair of `[\"X\"]` and `[\"Y\"]`. How can I do it?",
      "Given the following sample, the following filter will produce the following output:",
      "Assuming pairwise occurrences, and that \"between\" means excluding the border items, you could query the `indices` of the border items, and fetch everything in between.",
      "Here\u2019s the alternative, which has the possible advantage that it doesn\u2019t make any strong assumptions about the occurrence of the $x and $y values, and allows for both interpretations regarding the removal of the bookends themselves:",
      "# Input: an array\n# Remove all stretches from $x to the next $y,\n# removing both bookends too if and only if $bookends.\n# Both bookends must be present for a stretch to be removed.\ndef remove_all_xy($x; $y; $bookends):\n  # The helper function removes a single stretch from $x to $y, if any\n  def r:\n    index($x) as $ix\n    | if $ix then .[$ix+1:] as $tail\n      | ($tail | index($y)) as $iy\n      | if $iy  \n        then (if $bookends then 0 else 1 end) as $adjust\n        | .[:$ix + $adjust] + ($tail | .[1+$iy - $adjust:] | r)\n        else . end\n      else . end;\n  r;"
    ],
    "utterance": "Remove every segment of elements between each pair of [\"X\"] and [\"Y\"] in an array, excluding both bookends.",
    "expressions": [
      "[([indices([[\"X\"]]), indices([[\"Y\"]])] | 0, transpose[][], infinite) | _nwise(2) | as [$a, $b] | .[$a:$b+1][]]",
      "def remove_all_xy($x; $y; $bookends):\n  def r:\n    index($x) as $ix\n    | if $ix then .[$ix+1:] as $tail\n      | ($tail | index($y)) as $iy\n      | if $iy  \n        then (if $bookends then 0 else 1 end) as $adjust\n        | .[:$ix + $adjust] + ($tail | .[1+$iy - $adjust:] | r)\n        else . end\n      else . end;\n  r;"
    ],
    "data": [
      {
        "input": [
          [
            "A"
          ],
          [
            "B"
          ],
          [
            "X"
          ],
          [
            "C"
          ],
          [
            "D"
          ],
          [
            "Y"
          ],
          [
            "E"
          ],
          [
            "F"
          ],
          [
            "G"
          ],
          [
            "H"
          ],
          [
            "X"
          ],
          [
            "I"
          ],
          [
            "J"
          ],
          [
            "Y"
          ],
          [
            "K"
          ],
          [
            "L"
          ]
        ],
        "output": [
          [
            "A"
          ],
          [
            "B"
          ],
          [
            "X"
          ],
          [
            "Y"
          ],
          [
            "E"
          ],
          [
            "F"
          ],
          [
            "G"
          ],
          [
            "H"
          ],
          [
            "X"
          ],
          [
            "Y"
          ],
          [
            "K"
          ],
          [
            "L"
          ]
        ]
      }
    ],
    "identifier": 75491000
  },
  {
    "context": [
      "What needs to be done is that the operationId of each endpoint needs to be appended to each description.",
      "What eventually will happen is that there is another json file where keys are operationIds. So in the current file, I will need to append content to the descriptions from that third file based on operationId.",
      "So, please account for that when offering a solution."
    ],
    "utterance": "Append to each operation's description the corresponding description value from a mapping file using the operationId as the key.",
    "expressions": [
      ". as $openapi | ($mapping_file | . as $endpoint_descriptions | $openapi.paths |= with_entries( .value |= with_entries( if has(\"operationId\") and has(\"description\") and ($endpoint_descriptions[.value.operationId]? // null) then .value.description += ($endpoint_descriptions[.value.operationId].description) else . end )))"
    ],
    "identifier": 75512403
  },
  {
    "context": [
      "The result from a `iam list-groups-for-user --user-name \"User1\" | jq '.Groups[] | . += {name: \"User1\", groups: [.GroupName]} | {name, groups}'` provides the following result:",
      "What I want to achieve is a more concise result where the group names are all added to a single array owned by a shared attribute, the `name`, for example:",
      "If all you want to do is create an object with a made-up username and a list of group names, then construct a new object with the required properties and use `map` to transform the existing list:",
      "{\n  \"name\": \"User1\",\n  \"groups\": .Groups | map(.GroupName)\n}",
      "Or a stream & collect approach (this is how `map` is implemented):",
      "{\n  \"name\": \"User1\",\n  \"groups\": [.Groups[].GroupName]\n}"
    ],
    "utterance": "Create an object with a given user name and an array containing all group names from the Groups list.",
    "expressions": [
      "{name: \"User1\", groups: .Groups | map(.GroupName)}",
      "{name: \"User1\", groups: [.Groups[].GroupName]}"
    ],
    "data": [
      {
        "input": {
          "Groups": [
            {
              "Path": "/",
              "CreateDate": "2013-05-06T01:18:08Z",
              "GroupId": "AKIAIOSFODNN7EXAMPLE",
              "Arn": "arn:aws:iam::123456789012:group/Admin",
              "GroupName": "Admin"
            },
            {
              "Path": "/",
              "CreateDate": "2013-05-06T01:37:28Z",
              "GroupId": "AKIAI44QH8DHBEXAMPLE",
              "Arn": "arn:aws:iam::123456789012:group/s3-Users",
              "GroupName": "s3-Users"
            }
          ]
        },
        "output": {
          "name": "User1",
          "groups": [
            "Admin",
            "s3-Users"
          ]
        }
      }
    ],
    "identifier": 75512573
  },
  {
    "context": [
      "When trying to minify a deeply nested JSON file (~10k deep) using `jq` I got a parse error:\n```console\n$ jq -c . <input.json >minified.json\nparse error: Exceeds depth limit for parsing at line 227263, column 355\n```",
      "How can I increase the depth limit? Is there a command line option? I couldn't find anything about this in the man page.",
      "Regarding the C implementation, you'd have to remake the binary after changing MAX_PARSING_DEPTH in jv_parse.c, in which the relevant line is currently:\n\n    #define MAX_PARSING_DEPTH (256)\n\nAs best I can tell, there does not seem to be any downside to increasing the limit to a very large number.",
      "If you're on a version lower than 1.8.0, upgrade `jq` to version 1.8.0 or higher (released June 2025).\n\nVersion 1.8 increased the depth limit from 256 to 10,000 which should work in most cases."
    ],
    "utterance": "Minify a file containing objects nested to a depth of approximately 10,000 levels.",
    "expressions": [
      ".",
      "-c ."
    ],
    "identifier": 75524357
  },
  {
    "context": [
      "How can i append a string to existing json or re-write to new json.",
      "Here is my existing json",
      "[\n      {\n        \"Robin\": \"id1\"\n      },\n      {\n        \"John\": \"id2\"\n      },\n      {\n        \"Jane\": \"id3\"\n      }\n    ]",
      "The expected json is ",
      "{\n\"Objects\":\n[\n      {\n        \"Robin\": \"id1\"\n      },\n      {\n        \"John\": \"id2\"\n      },\n      {\n        \"Jane\": \"id3\"\n      }\n    ]\n}",
      "To go from your given input to the given output, construct a new object with the [{}` filter](https://stedolan.github.io/jq/manual/#ObjectConstruction:{}) defining a single property which has the full input array (via [identity `.`](https://stedolan.github.io/jq/manual/#Identity:.) filter) as value:",
      "{ Objects: . }",
      "If the key's name itself is variable, you can define a variable to be used by jq:",
      "jq --arg key Objects '{ $key: . }' input.json > output.json"
    ],
    "utterance": "Wrap an array as the value of a new top-level property named Objects.",
    "expressions": [
      "{ Objects: . }",
      "{ ($key): . }"
    ],
    "data": [
      {
        "input": [
          {
            "Robin": "id1"
          },
          {
            "John": "id2"
          },
          {
            "Jane": "id3"
          }
        ],
        "output": {
          "Objects": [
            {
              "Robin": "id1"
            },
            {
              "John": "id2"
            },
            {
              "Jane": "id3"
            }
          ]
        }
      }
    ],
    "identifier": 75529330
  },
  {
    "context": [
      "echo '{\"list\": [{\"name\": \"Cathy\", \"has\": \"apples\"}, {\"name\": \"Bob\", \"has\": \"bananas\"}]}' | jq '.list[] | .name as $n | {\"n\": $n}'",
      "If you want vanilla jq experience on YAML files, use [the other implementation](https://stackoverflow.com/tags/yq/info) of yq, [kislyuk/yq](https://github.com/kislyuk/yq), which is just a wrapper on jq, written in Python. Using that, you'd get:\n```sh\nyq -y '.[] | .name as $n | {\"n\": $n}' test.yaml\n```",
      "If you want to keep using mikefarah/yq, use parens to explicate the context:\n```sh\nyq '(.[] | .name) as $n | {\"n\": $n}' test.yaml\n```",
      "gojq --yaml-input --yaml-output '.[] | .name as $n | {\"n\": $n}' test.yaml"
    ],
    "utterance": "Output objects each containing the key 'n' with the value of each element's 'name' field from an array of objects.",
    "expressions": [
      ".list[] | .name as $n | {\"n\": $n}",
      "(.[] | .name) as $n | {\"n\": $n}",
      ".[] | .name as $n | {\"n\": $n}"
    ],
    "data": [
      {
        "input": {
          "list": [
            {
              "name": "Cathy",
              "has": "apples"
            },
            {
              "name": "Bob",
              "has": "bananas"
            }
          ]
        },
        "output": [
          {
            "n": "Cathy"
          },
          {
            "n": "Bob"
          }
        ]
      }
    ],
    "identifier": 75524947
  },
  {
    "context": [
      "I have following json structure ... I need to dump values of id fields, alphabetically sorted and without duplicates.",
      "desired output:",
      "abcd",
      "efgh",
      "`jq '.root.elements[].id'` - will dump me data i need",
      "i found 'unique' jq command should do both - sorting and removing duplicates - but after some testing i found out that it requires an array of strings/numbers but here im working with array of objects instead",
      "i would like to have this os independent, i cannot use unix utlities like sort and unique",
      "`unique` works with complex objects too and does not require simple strings. Thus, you can simple dedupe the objects in the array, then stream their ids:",
      ".root.elements | unique[].id",
      "Alternatively, [map] the array to a new array consisting only of ids, dedupe and then stream:",
      ".root.elements | map(.id) | unique[]"
    ],
    "utterance": "Extract the id fields from the elements array, sorted alphabetically and with duplicates removed.",
    "expressions": [
      ".root.elements | unique[].id",
      ".root.elements | map(.id) | unique[]"
    ],
    "data": [
      {
        "input": {
          "root": {
            "elements": [
              {
                "id": "abcd"
              },
              {
                "id": "efgh"
              },
              {
                "id": "abcd"
              }
            ]
          }
        },
        "output": [
          "abcd",
          "efgh"
        ]
      }
    ],
    "identifier": 75529770
  },
  {
    "identifier": 75537383
  },
  {
    "context": [
      "However, I want to include the label keys along with their values and I want to print the headers on the first row, something like resource_name, asset_type, labels. So expected output would look like -\nresource_name   asset_type    labels\n\n\"//storage.googleapis.com/testing-list-api\",\"storage.googleapis.com/Bucket\",\"application:gcs-bucket\",\"testing:api\"",
      "If you are fine with the three-part header shown in the Q, then you could use the following:\n  [\"resource_name\",\"asset_type\", \"labels\"],\n  \n  [.name,.asset_type, \n   ( .resource.data.labels // empty | to_entries[] | \"\\(.key):\\(.value)\") ]\n  | @csv"
    ],
    "utterance": "Produce a CSV with a header row resource_name, asset_type, labels, and include each label key and its value as separate fields in the row, formatted as key:value.",
    "expressions": [
      "[\"resource_name\",\"asset_type\", \"labels\"],\n[.name,.asset_type, ( .resource.data.labels // empty | to_entries[] | \"\\(.key):\\(.value)\") ]\n| @csv"
    ],
    "data": [
      {
        "input": {
          "name": "//storage.googleapis.com/testing-list-api",
          "asset_type": "storage.googleapis.com/Bucket",
          "resource": {
            "version": "v1",
            "discovery_document_uri": "https://www.googleapis.com/discovery/v1/apis/storage/v1/rest",
            "discovery_name": "Bucket",
            "parent": "//cloudresourcemanager.googleapis.com/projects/503672515986",
            "data": {
              "acl": [],
              "autoclass": {},
              "billing": {},
              "cors": [],
              "defaultObjectAcl": [],
              "encryption": {},
              "etag": "CAE=",
              "iamConfiguration": {
                "bucketPolicyOnly": {
                  "enabled": true,
                  "lockedTime": "2023-05-10T15:38:33.688Z"
                },
                "publicAccessPrevention": "enforced",
                "uniformBucketLevelAccess": {
                  "enabled": true,
                  "lockedTime": "2023-05-10T15:38:33.688Z"
                }
              },
              "id": "testing-list-api",
              "kind": "storage#bucket",
              "labels": {
                "application": "gcs-bucket",
                "testing": "api"
              },
              "lifecycle": {
                "rule": []
              },
              "location": "US",
              "locationType": "multi-region",
              "logging": {},
              "metageneration": 1,
              "name": "testing-list-api",
              "owner": {},
              "projectNumber": 503672515986,
              "retentionPolicy": {},
              "selfLink": "https://www.googleapis.com/storage/v1/b/testing-list-api",
              "storageClass": "STANDARD",
              "timeCreated": "2023-02-09T15:38:33.688Z",
              "updated": "2023-02-09T15:38:33.688Z",
              "versioning": {},
              "website": {}
            },
            "location": "us"
          },
          "ancestors": [
            "projects/503672515986"
          ],
          "update_time": "2023-02-09T15:38:33.688Z"
        },
        "output": [
          "\"resource_name\",\"asset_type\",\"labels\"",
          "\"//storage.googleapis.com/testing-list-api\",\"storage.googleapis.com/Bucket\",\"application:gcs-bucket\",\"testing:api\""
        ]
      }
    ],
    "identifier": 75513381
  },
  {
    "context": [
      "Is there a way in jq to map this data back to multiline string ?",
      "I need to map it back to a string that looks like this:",
      "`jq` has a  `join` function:",
      "cmd=$(jq -r '. | join(\"\")' data.json)",
      "Just run `add` on the array, use `-r` for raw output (i.e. no escapes):",
      "jq -r 'add' file.json",
      "As the lines already contain their newline symbols, you could instruct jq to omit its owns by using the `-j` option:",
      "jq -j '.[]' file.json"
    ],
    "utterance": "Recombine an array of shell command lines, each ending with a newline, into a single multiline shell command string.",
    "expressions": [
      ". | join(\"\")",
      "add",
      ".[]"
    ],
    "data": [
      {
        "input": [
          "newcert \\\n",
          "    --cn server1.acme.com \\\n",
          "    --san-dns server1.acme.com \\\n",
          "    --key-file ./config/key.pem \\\n",
          "    --csr-file ./config/csr.pem \\\n",
          "    --no-prompt \\\n"
        ],
        "output": "newcert \\\n    --cn server1.acme.com \\\n    --san-dns server1.acme.com \\\n    --key-file ./config/key.pem \\\n    --csr-file ./config/csr.pem \\\n    --no-prompt \\\n"
      }
    ],
    "identifier": 75535200
  },
  {
    "context": [
      "what are my options for determining the depth of nesting of a JSON document at the command-line?",
      "The streaming parser that comes with jq does not seem to impose any particular limit and can be used as follows:",
      "jq --stream -n '[inputs[0]|length]|max' input.json",
      "def max(s): reduce s as $_ (null; if $_ > . then $_ else . end); max(inputs[0]|length)",
      "gojq 'def max(s): reduce s as $_ (null; if $_ > . then $_ else . end); max(paths|length)' input.json"
    ],
    "utterance": "Determine the maximum nesting depth of a document, even with deeply nested data.",
    "expressions": [
      "jq --stream -n '[inputs[0]|length]|max' input.json",
      "def max(s): reduce s as $_ (null; if $_ > . then $_ else . end); max(inputs[0]|length)",
      "gojq 'def max(s): reduce s as $_ (null; if $_ > . then $_ else . end); max(paths|length)' input.json"
    ],
    "identifier": 75541601
  },
  {
    "context": [
      "JSON file:\r\n```\r\n{\r\n\"secret\": \"\",\r\n\"name\": \"test\"\r\n}\r\n```",
      "Expected Output:\r\n```\r\n{\r\n\"secret\": \"ABCDEFGH\",\r\n\"name\": \"test\"\r\n}\r\n```",
      "echo $(jq --arg a \"${{ secrets.MY_SECRET }}\" '.secret = ($a)' test.json) > test.json"
    ],
    "utterance": "Replace the value of the 'secret' key in an object with the value of a shell variable.",
    "expressions": [
      "jq --arg a \"$VAR\" '.secret = ($a)' input.json > output.json"
    ],
    "data": [
      {
        "input": {
          "secret": "",
          "name": "test"
        },
        "output": {
          "secret": "ABCDEFGH",
          "name": "test"
        }
      }
    ],
    "identifier": 75546117
  },
  {
    "context": [
      "My goal is to replace `PR_DESCRIPTION` in `payload.json` with the formatted text in `pr_body.txt`",
      "I tried to use `jq` to update my JSON but due to array object I struggle to find the right way to do it.",
      "select the nodes with path `.blocks[].text.text` and content `\"PR_DESCRIPTION\"`, and set their values to the markdown input, previously stored in a variable:",
      "< pr_body.txt jq -Rs --argfile json payload.json '. as $md | $json\n  | (.blocks[].text.text | select(. == \"PR_DESCRIPTION\")) = $md\n'"
    ],
    "utterance": "Replace the value of the property `.blocks[].text.text` where its current value is `PR_DESCRIPTION` with the contents of an external text file.",
    "expressions": [
      ". as $md | $json | (.blocks[].text.text | select(. == \"PR_DESCRIPTION\")) = $md"
    ],
    "data": [
      {
        "input": {
          "text": "Deployment started :rocket:",
          "blocks": [
            {
              "type": "header",
              "text": {
                "type": "plain_text",
                "text": ":computer:  Deployment release  :computer:"
              }
            },
            {
              "type": "context",
              "elements": [
                {
                  "type": "mrkdwn",
                  "text": "*${{ steps.date.outputs.date }} | STAGING*"
                }
              ]
            },
            {
              "type": "divider"
            },
            {
              "type": "section",
              "text": {
                "type": "mrkdwn",
                "text": "PR_DESCRIPTION"
              }
            },
            {
              "type": "divider"
            },
            {
              "type": "actions",
              "elements": [
                {
                  "type": "button",
                  "text": {
                    "type": "plain_text",
                    "text": "\ud83e\udd98 Pipeline"
                  },
                  "url": "${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}"
                }
              ]
            }
          ],
          "attachments": [
            {
              "color": "warning",
              "fields": [
                {
                  "title": "Statut",
                  "short": true,
                  "value": "Deploying ..."
                }
              ]
            }
          ]
        },
        "output": {
          "text": "Deployment started :rocket:",
          "blocks": [
            {
              "type": "header",
              "text": {
                "type": "plain_text",
                "text": ":computer:  Deployment release  :computer:"
              }
            },
            {
              "type": "context",
              "elements": [
                {
                  "type": "mrkdwn",
                  "text": "*${{ steps.date.outputs.date }} | STAGING*"
                }
              ]
            },
            {
              "type": "divider"
            },
            {
              "type": "section",
              "text": {
                "type": "mrkdwn",
                "text": "### TITLE\n\n\n**bold text**\n\n\n- qsqds\n- qsdqds\n- qsdqsd\n- qsdqsd\n\n1. qsdqsd\n2. qsdqsd\n3. qsdqsd\n4. qsdqsd\n\n`some code here`\n"
              }
            },
            {
              "type": "divider"
            },
            {
              "type": "actions",
              "elements": [
                {
                  "type": "button",
                  "text": {
                    "type": "plain_text",
                    "text": "\ud83e\udd98 Pipeline"
                  },
                  "url": "${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}"
                }
              ]
            }
          ],
          "attachments": [
            {
              "color": "warning",
              "fields": [
                {
                  "title": "Statut",
                  "short": true,
                  "value": "Deploying ..."
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 75537106
  },
  {
    "context": [
      "In jq, `--rawfile <variable-name> <filename>` will read in the named file and bind its content to the given global variable.",
      "But in versions of jq before 1.6, `--rawfile` is not present, what can I do?",
      "So we convert from:\n\n    jq ... --rawfile foo ./bar\n\nto\n\n    jq ... --argfile foo <( jq -s -R '.' ./bar )",
      "`jq -s -R '.'` reads `./bar` in one go because of `-s` thus obtaining a multiline string instead of an array, and it treats the input as raw text because of `-R` and emits a single json string output.",
      "Example:\n\n    $ printf 'one\\ntwo\\nthree\\n' > 123\n    $ jq -n --rawfile text 123 '{ text: $text }'\n    {\n      \"text\": \"one\\ntwo\\nthree\\n\"\n    }\n    $ jq -n --argfile text <( jq -s -R '.' 123 ) '{ text: $text }'\n    {\n      \"text\": \"one\\ntwo\\nthree\\n\"\n    }"
    ],
    "utterance": "Load the full content of a file as a string into a variable for use in programs, in versions before 1.6 where --rawfile is unavailable.",
    "expressions": [
      "--argfile text <( jq -s -R '.' FILENAME ) '{ text: $text }'"
    ],
    "data": [
      {
        "input": "one\ntwo\nthree\n",
        "output": {
          "text": "one\ntwo\nthree\n"
        }
      }
    ],
    "identifier": 75542815
  },
  {
    "context": [
      "So, values are passed as is without single quotes added in these:\r\n\r\n - `.exec.args[1]`\r\n - `.exec.env[1].value`\r\n\r\nExactly to content in json.",
      "A corrected version of your document might look like:\r\n\r\n```json\r\n{\r\n  \"exec\": {\r\n    \"apiVersion\": \"client.authentication.k8s.io/v1beta1\",\r\n    \"args\": [\r\n      \"-c\",\r\n      \"sops --decrypt \\\"${tokens_file}\\\" | jq -cM '{\\\"kind\\\": \\\"ExecCredential\\\", \\\"apiVersion\\\": \\\"client.authentication.k8s.io/v1beta1\\\", \\\"spec\\\": {}, \\\"status\\\" : {\\\"token\\\":.tokens[$ENV.context]}}'\"\r\n    ],\r\n    \"command\": \"bash\",\r\n    \"env\": [\r\n      {\r\n        \"name\": \"context\",\r\n        \"value\": \"utility\"\r\n      },\r\n      {\r\n        \"name\": \"tokens_file\",\r\n        \"value\": \"/home/some-user/.kube/tokens with space in name.enc.json\"\r\n      }\r\n    ]\r\n  }\r\n}"
    ],
    "utterance": "Obtain the values of .exec.args[1] and .exec.env[1].value exactly as they appear in the input, without adding or removing any quotes.",
    "expressions": [
      ".exec.args[1]",
      ".exec.env[1].value"
    ],
    "data": [
      {
        "input": {
          "exec": {
            "apiVersion": "client.authentication.k8s.io/v1beta1",
            "args": [
              "-c",
              "sops --decrypt \"${tokens_file}\" | jq -cM '{\"kind\": \"ExecCredential\", \"apiVersion\": \"client.authentication.k8s.io/v1beta1\", \"spec\": {}, \"status\" : {\"token\":.tokens[$ENV.context]}}'"
            ],
            "command": "bash",
            "env": [
              {
                "name": "context",
                "value": "utility"
              },
              {
                "name": "tokens_file",
                "value": "/home/some-user/.kube/tokens with space in name.enc.json"
              }
            ]
          }
        },
        "output": [
          "sops --decrypt \"${tokens_file}\" | jq -cM '{\"kind\": \"ExecCredential\", \"apiVersion\": \"client.authentication.k8s.io/v1beta1\", \"spec\": {}, \"status\" : {\"token\":.tokens[$ENV.context]}}'",
          "/home/some-user/.kube/tokens with space in name.enc.json"
        ]
      }
    ],
    "identifier": 75514391
  },
  {
    "context": [
      "If the array is empty, nothing will be streamed (and consequently, the product will be empty; see example at the bottom).",
      "Note that `?` only has an effect on missing values/properties. An empty array is not missing, it has a value: the empty array itself.",
      "You  probably want to use the `map` filter, e.g. to extract an array of ids from your connections: `{ connections: (.connections | map({id})) }`."
    ],
    "utterance": "Extract each app's id, an array of its actions' ids, and an array of its connections' ids, ensuring that if connections is an empty array the output contains an empty array for connections.",
    "expressions": [
      ".apps[] | { id, actions: (.actions | map({id})), connections: (.connections | map({id})) }"
    ],
    "data": [
      {
        "input": {
          "apps": [
            {
              "id": "1a902fb4-1b43-4df9-b9d7-9b54cd14e2ad",
              "actions": [
                {
                  "id": "0dc38f41-49fe-4056-b035-850764733a44"
                }
              ],
              "connections": []
            }
          ]
        },
        "output": {
          "id": "1a902fb4-1b43-4df9-b9d7-9b54cd14e2ad",
          "actions": [
            {
              "id": "0dc38f41-49fe-4056-b035-850764733a44"
            }
          ],
          "connections": []
        }
      }
    ],
    "identifier": 75549123
  },
  {
    "context": [
      "I have a bash string `default` with content ... and a file `override.json` with content ... I want to recursively merge these using `jq` to produce the result ...",
      "With the updated question (which now has valid JSON in the `default` variable), jq should be invoked as follows:",
      "jq --argjson defaults \"$default\" '$defaults * .' override.json"
    ],
    "utterance": "Recursively merge a variable containing object data with the contents of a file, so that keys in the file override those in the variable and unknown keys are preserved.",
    "expressions": [
      "jq --argjson defaults \"$default\" '$defaults * .' override.json"
    ],
    "data": [
      {
        "input": {
          "default": {
            "horses": {
              "count": 0,
              "fizz": "buzz"
            },
            "admin": {
              "enabled": false
            }
          },
          "override.json": {
            "horses": {
              "count": 1,
              "foo": "bar"
            },
            "admin": {
              "enabled": true
            }
          }
        },
        "output": {
          "horses": {
            "count": 1,
            "fizz": "buzz",
            "foo": "bar"
          },
          "admin": {
            "enabled": true
          }
        }
      }
    ],
    "identifier": 75554178
  },
  {
    "context": [
      "I only need the actual IP addresses, not the subnets, and I only need the IP addresses once.",
      "EDIT - updated with the validated JSON.",
      "now getting an error using the command jq --raw-output '.addresses[]'",
      "tried doing '.result.addresses[]' or '.status.addresses[]'",
      "jq --raw-output '.result | .[].addresses[]'",
      "It works. I have no idea if this is a well-formatted or thought out jq command, but it outputs the IPs in both my test file and the real data."
    ],
    "utterance": "Extract all unique IP addresses from the addresses array inside each object of the result array.",
    "expressions": [
      ".result | .[].addresses[]"
    ],
    "data": [
      {
        "input": {
          "status": "success",
          "result": [
            {
              "address_details": [
                {
                  "address": "135.138.168.78",
                  "serviceType": "go_gateway",
                  "addressType": "active",
                  "create_time": 1631879023,
                  "allow_listed": false
                },
                {
                  "address": "135.138.168.79",
                  "serviceType": "gp_gateway",
                  "addressType": "active",
                  "create_time": 1631879023,
                  "allow_listed": false
                }
              ],
              "zone": "Germany",
              "addresses": [
                "135.138.168.78",
                "135.138.168.79"
              ],
              "zone_subnet": [
                "137.183.192.0/18",
                "208.27.0.0/16",
                "34.3.0.0/16",
                "34.199.0.0/16",
                "66.59.192.0/19",
                "165.11.128.0/17",
                "135.138.0.0/16",
                "130.141.0.0/16",
                "165.185.0.0/16"
              ],
              "addresses_v6": [],
              "address_details_v6": []
            }
          ]
        },
        "output": [
          "135.138.168.78",
          "135.138.168.79"
        ]
      }
    ],
    "identifier": 75549196
  },
  {
    "context": [
      "I have two bash arrays:\r\n```bash\r\narr1=\"200 300 400\"\r\narr2=(1000 10001 10002)\r\n```",
      "I would like to produce a `json` file with a bash script:\r\n\r\n```json\r\n{\r\n  \"200\": {\"feature1\": 1000},\r\n  \"300\": {\"feature1\": 1001},\r\n  \"400\": {\"feature1\": 1002}\r\n}\r\n```",
      "but this only expands the whole arrays into one entry.",
      "Only `arr2` is an array. `arr1` is just a string containing spaces. Therefore you can read in `arr1` using the `--arg` option, and `/ \" \"` to split it at the spaces, and use the `--args` option for the \"real\" array `arr2`:",
      "jq -n --arg arg \"$arr1\" '[$arg / \" \", $ARGS.positional]\n  | reduce transpose[] as [$key, $feature1] ({}; .[$key] = {$feature1})\n' --args \"${arr2[@]}\"",
      "jq -n --arg arg \"$arr1\" '[$arg / \" \", $ARGS.positional]\n  | reduce transpose[] as [$key, $val] ({}; .[$key] = {feature1: $val | tonumber})\n' --args \"${arr2[@]}\"",
      "{\n  \"200\": {\n    \"feature1\": 1000\n  },\n  \"300\": {\n    \"feature1\": 10001\n  },\n  \"400\": {\n    \"feature1\": 10002\n  }\n}"
    ],
    "utterance": "Create an object where each key from arr1 is mapped to an object with feature1 set to the corresponding value from arr2, converting values to numbers.",
    "expressions": [
      "jq -n --arg arg \"$arr1\" '[$arg / \" \", $ARGS.positional] | reduce transpose[] as [$key, $val] ({}; .[$key] = {feature1: $val | tonumber})' --args \"${arr2[@]}\""
    ],
    "data": [
      {
        "input": {
          "arr1": "200 300 400",
          "arr2": [
            1000,
            10001,
            10002
          ]
        },
        "output": {
          "200": {
            "feature1": 1000
          },
          "300": {
            "feature1": 10001
          },
          "400": {
            "feature1": 10002
          }
        }
      }
    ],
    "identifier": 75545347
  },
  {
    "context": [
      "So how to trivially write exact matching, string-is-contained-in-array-contains?",
      "jq [offers](https://stedolan.github.io/jq/manual/#any%2Cany%28condition%29%2Cany%28generator%3Bcondition%29) the `any` filter to test if in a given stream at least one item evaluates to `true` for a given filter. For that filter you could use the equals `==` operator which evaluates to `true` for exact matches, and for the stream, if omitted, `any` will [default](https://github.com/stedolan/jq/blob/master/src/builtin.jq#L184) to the items of an input array.",
      "$ yq -n '[\"hyper\"] | any(. == \"pe\")'",
      "$ yq -n '[\"hyper\"] | any(. == \"hyper\")'",
      "Assuming a jq-like implementation, you'd use [`IN`](https://stedolan.github.io/jq/manual/#SQL-StyleOperators) (capitalized)",
      "$ jq -n --arg elem \"pe\"    '[\"hyper\"] as $list | $elem | IN($list[])'",
      "$ jq -n --arg elem \"hyper\" '[\"hyper\"] as $list | $elem | IN($list[])'"
    ],
    "utterance": "Test if an array contains an exact string match for a given value, such as checking if \"hyper\" exists as a full item.",
    "expressions": [
      "any(. == \"hyper\")",
      "--arg elem \"hyper\" '[\"hyper\"] as $list | $elem | IN($list[])'"
    ],
    "data": [
      {
        "input": [
          "hyper"
        ],
        "output": true
      },
      {
        "input": [
          "hyper"
        ],
        "output": false
      }
    ],
    "identifier": 75555150
  },
  {
    "context": [
      "Is there a way I can select the value where key=OS instead of selecting the specific array value?",
      ".Tags | from_entries | .OS",
      ".Tags | first( .[] | select(.Key == \"OS\") | .Value)"
    ],
    "utterance": "Get the value associated with the key OS from the Tags array, regardless of the order of its elements.",
    "expressions": [
      ".Tags | from_entries | .OS",
      ".Tags | first( .[] | select(.Key == \"OS\") | .Value)"
    ],
    "data": [
      {
        "input": {
          "Tags": [
            {
              "Key": "Name",
              "Value": "db01"
            },
            {
              "Key": "BackupResourceType",
              "Value": "EC2"
            },
            {
              "Key": "Role",
              "Value": "db_edi01"
            },
            {
              "Key": "OS",
              "Value": "Ubuntu 18.04"
            }
          ]
        },
        "output": "Ubuntu 18.04"
      }
    ],
    "identifier": 75560114
  },
  {
    "context": [
      "It's not clear to me why my output with this template is missing the first line of the data, what am I missing?",
      "JQ Template (called with --raw-data flag):",
      "{ south: [inputs | split(\";\") | {label: .[0], date: .[1], values: .[2] | gsub(\"[\\r]\"; \"\") | tonumber } ]  \n| group_by(.label) | map({ key: (.[0].label), value: [.[] | {date: .date, values: .values}] }) | from_entries\n}",
      "If I examine the results, the first entry is missing. I do not understand why.",
      "Add the `-n` or `--null-input` option. (On jqplay.org tick the checkbox reading \"Null Input\").",
      "This is because the first input is consumed by the context `.`, and any subsequent inputs are consumed either by reiteration to `.` (which happens programmatically), or earlier, if present, by the use of `input` (one) or `inputs` (all)."
    ],
    "utterance": "Group all semicolon-separated data lines by their first field, keeping all lines, including the first, in the output.",
    "expressions": [
      "{ south: [inputs | split(\";\") | {label: .[0], date: .[1], values: .[2] | gsub(\"[\\r]\"; \"\") | tonumber }] | group_by(.label) | map({ key: (.[0].label), value: [.[] | {date: .date, values: .values}] }) | from_entries }"
    ],
    "data": [
      {
        "input": "watts;2023-02-21T06:50:00+01:00;0\nwatts;2023-02-21T07:00:00+01:00;1928",
        "output": {
          "south": {
            "watts": [
              {
                "date": "2023-02-21T06:50:00+01:00",
                "values": 0
              },
              {
                "date": "2023-02-21T07:00:00+01:00",
                "values": 1928
              }
            ]
          }
        }
      }
    ],
    "identifier": 75548994
  },
  {
    "context": [
      "\"I have a file.txt with this in it:\\r\\n\\r\\n{\\\"user1\\\": 10, \\\"joe\\\": 13, \\\"jane\\\": 55}\\r\\n\\r\\nI would like to format this so that it produces the following result:\"",
      "\"{\\r\\n\\\"user.user1\\\": 10,\\r\\n\\\"user.joe\\\": 13,\\r\\n\\\"user.jane\\\": 55,\\r\\n}\"",
      "\"Use `with_entries`, and update `|=` the `.key`:\\r\\n```sh\\r\\njq --arg u 'user' 'with_entries(.key |= $u + \".\" + .)' file.txt\\r\\n```\"",
      "\"{\\r\\n  \\\"user.user1\\\": 10,\\r\\n  \\\"user.joe\\\": 13,\\r\\n  \\\"user.jane\\\": 55\\r\\n}\""
    ],
    "utterance": "Prefix all keys in the object with 'user.' so that, for example, 'user1' becomes 'user.user1', 'joe' becomes 'user.joe', and 'jane' becomes 'user.jane'.",
    "expressions": [
      "with_entries(.key |= \"user.\" + .)",
      "with_entries(.key |= $u + \".\" + .)"
    ],
    "data": [
      {
        "input": {
          "user1": 10,
          "joe": 13,
          "jane": 55
        },
        "output": {
          "user.user1": 10,
          "user.joe": 13,
          "user.jane": 55
        }
      }
    ],
    "identifier": 75560037
  },
  {
    "context": [
      "I am trying to traverse the first file (swagger.json) and append each endpoint's description with the content from the look-up file (endpoint-descriptions.json) based on the operationId which acts as a key in the second file.",
      "jq --argfile lookup endpoint-descriptions.json '.paths[][] |= (\n  .description += ($lookup[.operationId].description | \" \" + values // \"\")\n)' swagger.json"
    ],
    "utterance": "For each endpoint in a Swagger file, append the description string with a value from a lookup table where operationId is the key.",
    "expressions": [
      "jq --argfile lookup endpoint-descriptions.json '.paths[][] |= (.description += ($lookup[.operationId].description | \" \" + values // \"\"))' swagger.json"
    ],
    "data": [
      {
        "input": {
          "swagger.json": {
            "paths": {
              "/cloud/{cloud_type}/{id}": {
                "put": {
                  "description": "Update information related to a cloud account.",
                  "operationId": "update-cloud-account"
                }
              }
            }
          },
          "endpoint-descriptions.json": {
            "update-cloud-account": {
              "description": "The request body parameters differ depending on the cloud type of the account you want to add."
            }
          }
        },
        "output": {
          "paths": {
            "/cloud/{cloud_type}/{id}": {
              "put": {
                "description": "Update information related to a cloud account. The request body parameters differ depending on the cloud type of the account you want to add.",
                "operationId": "update-cloud-account"
              }
            }
          }
        }
      }
    ],
    "identifier": 75551855
  },
  {
    "context": [
      "I am trying parse the value of a json property whose key has hyphens in it.",
      "This approach works just fine if the $srcKey variable does NOT have any hyphens in it, but breaks with the following error if it has hyphens",
      "`jq: error: Part1OfHypenatedKey/0 is not defined at <top-level>`",
      "Tried putting just the variable with hyphens inside quotes - didnt make a difference",
      "Tried putting the entire jq key reference in quote - but didnt work at all, may be i was doing something wrong"
    ],
    "utterance": "Extract the value of a property whose key contains hyphens using a variable key name within a Bash script.",
    "expressions": [
      ".root.parent[$srcKey]"
    ],
    "identifier": 75586322
  },
  {
    "context": [
      "**Sample input**:",
      "Suppose that I cannot use recursive descent, for example I want to update only odd _someValue_.",
      ".very.\"un-fortunate\".\"p-a-t-h\"[].someValue |= . + 10",
      "(.very.\"un-fortunate\".\"p-a-t-h\"[].someValue | select(. % 2 != 0)) += 10",
      "walk(if try (.someValue % 2 != 0) catch false then .somevalue += 10 else . end)"
    ],
    "utterance": "Increase all odd someValue fields under .very[\"un-fortunate\"][\"p-a-t-h\"] by 10.",
    "expressions": [
      "(.very[\"un-fortunate\"][\"p-a-t-h\"][].someValue | select(. % 2 != 0)) += 10",
      "walk(if try (.someValue % 2 != 0) catch false then .someValue += 10 else . end)"
    ],
    "data": [
      {
        "input": {
          "very": {
            "un-fortunate": {
              "p-a-t-h": {
                "first": {
                  "veryDeepSubTree": {},
                  "someValue": 1
                },
                "second": {
                  "veryDeepSubTree": {},
                  "someValue": 2
                },
                "third": {
                  "veryDeepSubTree": {},
                  "someValue": 3
                }
              }
            }
          }
        },
        "output": {
          "very": {
            "un-fortunate": {
              "p-a-t-h": {
                "first": {
                  "veryDeepSubTree": {},
                  "someValue": 11
                },
                "second": {
                  "veryDeepSubTree": {},
                  "someValue": 2
                },
                "third": {
                  "veryDeepSubTree": {},
                  "someValue": 13
                }
              }
            }
          }
        }
      }
    ],
    "identifier": 75578551
  },
  {
    "context": [
      "So basing on what I have in `ARRAY` (keys) how can I output corresponding keys and values from `JSON` in order to have `TARGET_JSON` like this:\r\n\r\n    TARGET_JSON={\r\n      \"keyA\": \"valueA\",\r\n      \"keyC\": \"valueC\",\r\n      \"keyE\": \"valueE\"\r\n    }",
      "Or with user-provided variables:\r\n\r\n```\r\njq --argjson keys '[\"keyA\", \"keyC\", \"keyE\"]' '. as $obj\n| reduce $keys[] as $key ({}; .[$key] = $obj[$key])",
      "jq --argjson keys '[\"keyA\", \"keyC\", \"keyE\"]' 'with_entries(select(.key | IN($keys[])))'",
      "jq --argjson keys '[\"keyA\", \"keyC\", \"keyE\"]' 'INDEX($keys[]; .) as $keys\n| with_entries(select(.key | in($keys)))'"
    ],
    "utterance": "Select key-value pairs whose keys are present in the array [\"keyA\", \"keyC\", \"keyE\"]",
    "expressions": [
      ". as $obj | reduce [\"keyA\", \"keyC\", \"keyE\"][] as $key ({}; .[$key] = $obj[$key])",
      "jq --argjson keys '[\"keyA\", \"keyC\", \"keyE\"]' '. as $obj | reduce $keys[] as $key ({}; .[$key] = $obj[$key])'",
      "jq --argjson keys '[\"keyA\", \"keyC\", \"keyE\"]' 'with_entries(select(.key | IN($keys[])))'",
      "jq --argjson keys '[\"keyA\", \"keyC\", \"keyE\"]' 'INDEX($keys[]; .) as $keys | with_entries(select(.key | in($keys)))'"
    ],
    "data": [
      {
        "input": {
          "keyA": "valueA",
          "keyB": "valueB",
          "keyC": "valueC",
          "keyD": "valueD",
          "keyE": "valueE",
          "keyF": "valueF"
        },
        "output": {
          "keyA": "valueA",
          "keyC": "valueC",
          "keyE": "valueE"
        }
      }
    ],
    "identifier": 75578288
  },
  {
    "context": [
      "I have an array of ids, and a json that contains elements with these ids and more data. I need to filter/select the values that matches the ones in the array.",
      "I need to retrieve the values 10, 100, 5 and 17.",
      "$ IDS=(1 2 3 4)\n$ jq '.[] | select(IN(.id; $ARGS.positional[])) .value' file.json --jsonargs \"${IDS[@]}\"",
      "jq \\\n    --arg IDS \"${IDS[*]}\" \\\n    '($IDS | split(\" \") | map(tonumber)) as $PIDS | \n        .[] | select([.id] | index($PIDS[])).value' \\\ninput",
      "jq --arg idstr \"${ids[*]}\" '\n  ([$idstr | split(\" \")[] | {\"key\": ., \"value\": true}] | from_entries) as $idmap\n  | .[] | select($idmap[.id | tostring]).value'",
      "jq '\n  (\n    [$ARGS.positional[] | {\"key\": ., \"value\": true}] |\n    from_entries\n  ) as $idmap |\n  .[] |\n  select($idmap[.id | tostring]).value' \\\n  input.json \\\n  --args \"${ids[@]}\" "
    ],
    "utterance": "Select objects whose id field matches any of 1, 2, 3, or 4 and output their value fields.",
    "expressions": [
      ".[] | select(IN(.id; $ARGS.positional[])) .value",
      "($IDS | split(\" \") | map(tonumber)) as $PIDS | .[] | select([.id] | index($PIDS[])).value",
      "([$idstr | split(\" \")[] | {\"key\": ., \"value\": true}] | from_entries) as $idmap | .[] | select($idmap[.id | tostring]).value",
      "([$ARGS.positional[] | {\"key\": ., \"value\": true}] | from_entries) as $idmap | .[] | select($idmap[.id | tostring]).value"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "value": 10
          },
          {
            "id": 2,
            "value": 100
          },
          {
            "id": 3,
            "value": 5
          },
          {
            "id": 4,
            "value": 17
          },
          {
            "id": 5,
            "value": 84
          }
        ],
        "output": [
          10,
          100,
          5,
          17
        ]
      }
    ],
    "identifier": 75581831
  },
  {
    "context": [
      "I am trying to make JQ return an output that's nearly identical to the input, only chaing one property whose sibling matches a string.",
      "How can I return the data how it was structured originally, but with my changed value? I would rather not have to reassemble an array with the returned items and manually specify each original property.",
      "This will return the whole object with the updated value",
      "(.projects[] | select(.name == \"project1\").autoplan.enabled) |= true"
    ],
    "utterance": "Update the 'autoplan.enabled' property to true for the project whose name is 'project1', returning the entire data structure unchanged except for this update.",
    "expressions": [
      "(.projects[] | select(.name == \"project1\").autoplan.enabled) |= true"
    ],
    "data": [
      {
        "input": {
          "version": 3,
          "projects": [
            {
              "name": "project1",
              "autoplan": {
                "enabled": false
              }
            },
            {
              "name": "project2",
              "autoplan": {
                "enabled": false
              }
            }
          ],
          "workflows": {}
        },
        "output": {
          "version": 3,
          "projects": [
            {
              "name": "project1",
              "autoplan": {
                "enabled": true
              }
            },
            {
              "name": "project2",
              "autoplan": {
                "enabled": false
              }
            }
          ],
          "workflows": {}
        }
      }
    ],
    "identifier": 75586686
  },
  {
    "context": [
      "I'm getting lost on how to subtract 6 months from today's date using JQ.",
      "I know I can get today's date by doing `(now | todate | split(\"T\") | .[0])` but from there I'm not sure the best solution to subtract 6 months.",
      "Use `gmtime` and `mktime` (see the [manual](https://stedolan.github.io/jq/manual/#Dates)) to convert to and from a \"broken down time\", which is an array of items such as year, month, date etc. Substract, and re-assemble:",
      "now | gmtime | .[1] -= 6 | mktime | strftime(\"%FT%TZ\")"
    ],
    "utterance": "Produce the date exactly 6 months before the current date.",
    "expressions": [
      "now | gmtime | .[1] -= 6 | mktime | strftime(\"%FT%TZ\")"
    ],
    "identifier": 75608793
  },
  {
    "context": [
      "I am seeking the simultaneous iteration of two lists.",
      "There are no matching keys between the two object lists (which can easily be turned into arrays).",
      "Wanted Output Object List",
      "One way would be using `--slurpfile` to read in the files as arrays, then use `transpose` and `add` to \"zip\" them:\n```sh\njq --slurpfile s1 file1.json --slurpfile s2 file2.json -n \\\n  '[$s1, $s2] | transpose[] | add'\n```",
      "If the two files were already arrays, you can move from using `--slurpfile` to a single `--slurp` (or `-s`), then reading in the files as regular input files instead, and using the same \"zipping\" technique:\n```\njq -s 'transpose[] | add' arrayfile1.json arrayfile2.json\n```",
      "As illustrated by the accepted answer, one approach to the problem is to convert both streams to arrays, but this imposes an unnecessary memory requirement, as illustrated by the following solution, which requires that only one of the two streams be \"slurped\", and which incidentally also does not incur the various costs of `transpose`.",
      "```\n< s2 jq -n --slurpfile s1 s1 '\n  def zips(s): \n    . as $in\n    | foreach s as $x (-1; .+1; $in[.] + $x);\n  $s1 | zips(inputs)'\n```\n "
    ],
    "utterance": "Combine corresponding objects from two lists by merging the first object from each list, the second with the second, and so on, producing a new list of combined objects.",
    "expressions": [
      "jq --slurpfile s1 file1.json --slurpfile s2 file2.json -n '[$s1, $s2] | transpose[] | add'",
      "jq -s 'transpose[] | add' arrayfile1.json arrayfile2.json",
      "< s2 jq -n --slurpfile s1 s1 '\n  def zips(s): \n    . as $in\n    | foreach s as $x (-1; .+1; $in[.] + $x);\n  $s1 | zips(inputs)'"
    ],
    "data": [
      {
        "input": [
          {
            "k11": "v111",
            "k12": "v112"
          },
          {
            "k11": "v121",
            "k12": "v122"
          },
          {
            "k11": "v131",
            "k12": "v132"
          }
        ],
        "output": [
          {
            "k11": "v111",
            "k12": "v112",
            "k21": "v211",
            "k22": "v212"
          },
          {
            "k11": "v121",
            "k12": "v122",
            "k21": "v221",
            "k22": "v222"
          },
          {
            "k11": "v131",
            "k12": "v132",
            "k21": "v231",
            "k22": "v232"
          }
        ]
      },
      {
        "input": [
          {
            "k21": "v211",
            "k22": "v212"
          },
          {
            "k21": "v221",
            "k22": "v222"
          },
          {
            "k21": "v231",
            "k22": "v232"
          }
        ]
      }
    ],
    "identifier": 75587836
  },
  {
    "context": [
      "To restate the need, recursively profile each key in a JSON object if a value is an object or array. Solution needs to be key name independent.",
      "If a key maps to an array of objects then collect the unique keys across the objects and keep profiling down if there are nested arrays of objects there. If a value is an object, profile that object.",
      "Given your input.json, here is a solution :",
      "jq '\ndef schema:\n    if   type == \"object\" then .[] |= schema\n    elif type == \"array\"  then map(schema)|unique\n         | if (first | type) == \"object\" then [add] else . end\n    else type\n    end;\nschema\n' input.json",
      "Here's a variant of @Philippe's solution: it coalesces objects in `map(schema)` for arrays in a principled though lossy way.",
      "def combine($a;$b):\n  if $a == $b then $a elif $a == null then $b elif $b == null then $a\n  elif ($a == []) and ($b|type) == \"array\" then $b\n  elif ($b == []) and ($a|type) == \"array\" then $a\n  else \"JSON\"\n  end;\n\ndef mergeTypes(s):\n    reduce s as $t (null;\n       if ($t|type) != \"object\" then .types = (.types + [$t] | unique)\n       else .object as $o\n       | .object = reduce ($t | keys_unsorted[]) as $k ($o;\n                    .[$k] = combine( $t[$k]; $o[$k] ) \n\t\t  )\n       end)\n       | (if .object then [.object] else null end ) + .types ;\n\ndef schema:\n    if   type == \"object\" then .[] |= schema\n    elif type == \"array\"\n    then if . == [] then [] else mergeTypes(.[] | schema) end\n    else type\n    end;\nschema"
    ],
    "utterance": "Produce a structural type schema mapping each key to 'string', 'number', or recursively profiling nested objects and arrays, handling arbitrary keys and arbitrary structure.",
    "expressions": [
      "def schema:\n    if   type == \"object\" then .[] |= schema\n    elif type == \"array\"  then map(schema)|unique\n         | if (first | type) == \"object\" then [add] else . end\n    else type\n    end;\nschema",
      "def combine($a;$b):\n  if $a == $b then $a elif $a == null then $b elif $b == null then $a\n  elif ($a == []) and ($b|type) == \"array\" then $b\n  elif ($b == []) and ($a|type) == \"array\" then $a\n  else \"JSON\"\n  end;\n\ndef mergeTypes(s):\n    reduce s as $t (null;\n       if ($t|type) != \"object\" then .types = (.types + [$t] | unique)\n       else .object as $o\n       | .object = reduce ($t | keys_unsorted[]) as $k ($o;\n                    .[$k] = combine( $t[$k]; $o[$k] ) \n\t\t  )\n       end)\n       | (if .object then [.object] else null end ) + .types ;\n\ndef schema:\n    if   type == \"object\" then .[] |= schema\n    elif type == \"array\"\n    then if . == [] then [] else mergeTypes(.[] | schema) end\n    else type\n    end;\nschema"
    ],
    "data": [
      {
        "input": {
          "name": "XYZ Company",
          "type": "Contractors",
          "reporting": [
            {
              "group_id": "660",
              "groups": [
                {
                  "ids": [
                    987654321,
                    987654321,
                    987654321
                  ],
                  "market": {
                    "name": "Austin, TX",
                    "value": "873275"
                  }
                },
                {
                  "ids": [
                    987654321,
                    987654321,
                    987654321
                  ],
                  "market": {
                    "name": "Nashville, TN",
                    "value": "2393287"
                  }
                }
              ]
            }
          ],
          "product_agreements": [
            {
              "negotiation_arrangement": "FFVII",
              "code": "84144",
              "type": "DJ",
              "type_version": "V10",
              "description": "DJ in a mask",
              "name": "Claptone",
              "negotiated_rates": [
                {
                  "company_references": [
                    1,
                    5,
                    458
                  ],
                  "negotiated_prices": [
                    {
                      "type": "negotiated",
                      "rate": 17.73,
                      "expiration_date": "9999-12-31",
                      "code": [
                        "11"
                      ],
                      "billing_modifier_code": [
                        "124"
                      ],
                      "billing_class": "professional"
                    }
                  ]
                },
                {
                  "company_references": [
                    747
                  ],
                  "negotiated_prices": [
                    {
                      "type": "fee",
                      "rate": 28.42,
                      "expiration_date": "9999-12-31",
                      "code": [
                        "11"
                      ],
                      "billing_class": "professional"
                    }
                  ]
                }
              ]
            },
            {
              "negotiation_arrangement": "MGS3",
              "name": "David Byrne",
              "type": "Producer",
              "type_version": "V10",
              "code": "654321",
              "description": "Frontman from Talking Heads",
              "negotiated_rates": [
                {
                  "company_references": [
                    1,
                    9,
                    2344,
                    8456
                  ],
                  "negotiated_prices": [
                    {
                      "type": "negotiated",
                      "rate": 68.73,
                      "expiration_date": "9999-12-31",
                      "code": [
                        "11"
                      ],
                      "billing_class": "professional"
                    }
                  ]
                },
                {
                  "company_references": [
                    679
                  ],
                  "negotiated_prices": [
                    {
                      "type": "fee",
                      "rate": 89.25,
                      "expiration_date": "9999-12-31",
                      "code": [
                        "11"
                      ],
                      "billing_class": "professional"
                    }
                  ]
                }
              ]
            }
          ],
          "version": "1.3.1",
          "last_updated_on": "2023-02-01"
        },
        "output": {
          "name": "string",
          "type": "string",
          "reporting": [
            {
              "group_id": "number",
              "groups": [
                {
                  "ids": [
                    "number"
                  ],
                  "market": {
                    "name": "string",
                    "value": "string"
                  }
                }
              ]
            }
          ],
          "product_agreements": [
            {
              "negotiation_arrangement": "string",
              "code": "string",
              "type": "string",
              "type_version": "string",
              "description": "string",
              "name": "string",
              "negotiated_rates": [
                {
                  "company_references": [
                    "number"
                  ],
                  "negotiated_prices": [
                    {
                      "type": "string",
                      "rate": "number",
                      "expiration_date": "string",
                      "code": [
                        "string"
                      ],
                      "billing_modifier_code": [
                        "string"
                      ],
                      "billing_class": "string"
                    }
                  ]
                }
              ]
            }
          ],
          "version": "string",
          "last_updated_on": "string"
        }
      }
    ],
    "identifier": 75501520
  },
  {
    "context": [
      "Imagine we have two json objects:",
      "{ \"messages\":[\"one\"], \"keyA\": \"valueA\" }",
      "and",
      "{ \"messages\":[\"two\"], \"keyB\": \"valueB\" }",
      "I expect there's a way to merge these two objects while concatenating the array values, such that the resulting object would be:",
      "{ \"messages\":[\"one\",\"two\"], \"keyA\": \"valueA\", \"keyB\": \"valueB\" }",
      "Most of the approaches I've seen thus far to do this are inadequate in that the array gets overwritten by the \"right most\" object's version.",
      "Bonus points if the solution can handle an object whose array key's value is null as if it were an empty array:",
      "{ \"messages\":null, \"keyA\": \"valueA\"}{ \"messages\":[\"two\"], \"keyB\": \"valueB\" }",
      "`jq -s '[.[] | to_entries] | flatten | reduce .[] as $dot ({}; .[$dot.key] += $dot.value)'`",
      "Additionally, inspired by https://github.com/stedolan/jq/issues/957 I was able to do this:",
      "`jq -s '.[2].messages = .[0].messages + .[1].messages | .[0] + .[1] + .[2]'`",
      "Lastly, from that same issue, there's this:",
      "`jq -s '.[0] as $o1 | .[1] as $o2 | ($o1 + $o2) | .messages = ($o1.messages + $o2.messages)'`",
      "For simple examples such as in the question, the following filter provides a simple but principled approach that also qualifies for the \u201cbonus points\u201d:",
      "def combine($obj):\n  . as $in\n  | reduce ($obj|keys_unsorted[]) as $key\n      ($in;\n       if (.[$key] | type) == \"array\" then .[$key] += $obj[$key]\n       else .[$key] = $obj[$key]\n       end ) ;",
      "For more than two objects, simply use `reduce`, e.g. for an array of objects:",
      "def combine: if length==0 then . else reduce .[] as $_ ([]; combine($_));"
    ],
    "utterance": "Merge two or more objects, concatenating the arrays for keys present in both objects, and treating null array values as empty arrays.",
    "expressions": [
      "[.[] | to_entries] | flatten | reduce .[] as $dot ({}; .[$dot.key] += $dot.value)",
      ".[2].messages = .[0].messages + .[1].messages | .[0] + .[1] + .[2]",
      ".[0] as $o1 | .[1] as $o2 | ($o1 + $o2) | .messages = ($o1.messages + $o2.messages)",
      "def combine($obj):\n  . as $in\n  | reduce ($obj|keys_unsorted[]) as $key\n      ($in;\n       if (.[$key] | type) == \"array\" then .[$key] += $obj[$key]\n       else .[$key] = $obj[$key]\n       end ) ;",
      "def combine: if length==0 then . else reduce .[] as $_ ([]; combine($_));"
    ],
    "data": [
      {
        "input": [
          {
            "messages": [
              "one"
            ],
            "keyA": "valueA"
          },
          {
            "messages": [
              "two"
            ],
            "keyB": "valueB"
          }
        ],
        "output": {
          "messages": [
            "one",
            "two"
          ],
          "keyA": "valueA",
          "keyB": "valueB"
        }
      },
      {
        "input": [
          {
            "messages": null,
            "keyA": "valueA"
          },
          {
            "messages": [
              "two"
            ],
            "keyB": "valueB"
          }
        ],
        "output": {
          "messages": [
            "two"
          ],
          "keyA": "valueA",
          "keyB": "valueB"
        }
      }
    ],
    "identifier": 75596476
  },
  {
    "context": [
      "I would like to print `{score: score_value, id: id_value}`, by using `jq` from the following json script (only a small part is here for introduction), I tried ` jq '[score: .hits.hits[]._score, id: .hits.hits[]._id]'` and also ` jq '{.hits.hits[]._score, .hits.hits[]._id}'`, but both have compile error.",
      "To get a stream of elements (i.e. multiple JSON documents):\n\n```\n.hits.hits[] | { score: ._score, id: ._id }\n```",
      "Or to get a single JSON array:\n\n```\n.hits.hits | map({ score: ._score, id: ._id })\n```",
      "In order to extract the data you need, you can try something like this:\n\n```shell\njq '[.hits.hits[] | { id: ._id, score: ._score }]'\n```",
      "An alternative way to get the same result is to use the [`map()`](https://stedolan.github.io/jq/manual/#map(x),map_values(x)) filter. It runs the filter passed as argument against each item of the input array and collects the results into a new array.",
      "jq '.hits.hits | map({ id: ._id, score: ._score })'"
    ],
    "utterance": "Extract each element's _id and _score from hits.hits and create an array of objects with keys id and score.",
    "expressions": [
      ".hits.hits[] | { score: ._score, id: ._id }",
      ".hits.hits | map({ score: ._score, id: ._id })",
      "[.hits.hits[] | { id: ._id, score: ._score }]",
      ".hits.hits | map({ id: ._id, score: ._score })"
    ],
    "data": [
      {
        "input": {
          "took": 17,
          "timed_out": false,
          "_shards": {
            "total": 1,
            "successful": 1,
            "skipped": 0,
            "failed": 0
          },
          "hits": {
            "total": {
              "value": 100,
              "relation": "eq"
            },
            "max_score": 1.0,
            "hits": [
              {
                "_index": "ff0",
                "_id": "1",
                "_score": 1.0,
                "_source": {
                  "server_id": 86,
                  "@timestamp": "2023-03-01T11:09:23.474948161Z"
                }
              },
              {
                "_index": "ff0",
                "_id": "2",
                "_score": 0.8,
                "_source": {
                  "server_id": 99,
                  "@timestamp": "2023-03-01T12:09:23.474948161Z"
                }
              }
            ]
          }
        },
        "output": [
          {
            "id": "1",
            "score": 1.0
          },
          {
            "id": "2",
            "score": 0.8
          }
        ]
      }
    ],
    "identifier": 75612961
  },
  {
    "context": [
      "For each row, I want to create the following, where the first set of reads are suffixed with \"first\", and the second is suffixed with \"last\"\n[\n  {\n    \"forward\": \"forward-row1-first\",\n    \"reverse\": \"reverse-row1-first\"\n      },\n  {\n    \"forward\": \"forward-row1-last\",\n    \"reverse\": \"reverse-row1-last\"\n      }\n]",
      "Next, I would like to combine the above structure for each row in the file as the following:\n[\n  {\n    \"reads\": [\n      {\n        \"forward\": \"forward-row1-first\",\n        \"reverse\": \"reverse-row1-first\"\n      },\n      {\n        \"forward\": \"forward-row1-last\",\n        \"reverse\": \"reverse-row1-last\"\n      }\n    ]\n  },\n  {\n    \"reads\": [\n      {\n        \"forward\": \"forward-row2-first\",\n        \"reverse\": \"reverse-row2-first\"\n      },\n      {\n        \"forward\": \"forward-row2-last\",\n        \"reverse\": \"reverse-row2-last\"\n      }\n    ]\n  }\n]",
      "You can read the rows text file using the `-R` option. To iterate over the `inputs`, also use the `-n` option to start with the first line.\n\n```sh\njq -Rn '\n  reduce inputs as $row ([]; . += [{reads: [(\"first\", \"last\") as $sfx | {\n    forward: \"forward-\\($row)-\\($sfx)\",\n    reverse: \"reverse-\\($row)-\\($sfx)\"\n  }]}])\n' rows.txt\n```",
      "Not as clean as [@Pmf's solution][1], but without `reduce()`, you could `map()` over the rows, and create the desired objects by looping over `[ \"first, \"last\" ]` and create the object for each item:\n```\njq -Rn '\n    [ inputs ] \n        | map(. as $tmp \n        | { reads: [ ([ \"first\", \"last\" ] \n        | map({ forward: \"forward-\\($tmp)-\\(.)\", reverse: \"reverse-\\($tmp)-\\(.)\"})) \n    ] \n})'  input_file\n```"
    ],
    "utterance": "Generate an array where each row from an input file becomes an object containing a 'reads' array, with two objects: one with keys 'forward' and 'reverse' suffixed with '-first', and the other with '-last'.",
    "expressions": [
      "jq -Rn '\n  reduce inputs as $row ([]; . += [{reads: [(\"first\", \"last\") as $sfx | {\n    forward: \"forward-\\($row)-\\($sfx)\",\n    reverse: \"reverse-\\($row)-\\($sfx)\"\n  }]}])\n'",
      "jq -Rn '\n    [ inputs ] \n        | map(. as $tmp \n        | { reads: [ ([ \"first\", \"last\" ] \n        | map({ forward: \"forward-\\($tmp)-\\(.)\", reverse: \"reverse-\\($tmp)-\\(.)\"})) \n    ] \n})'"
    ],
    "data": [
      {
        "input": "row1\nrow2\n",
        "output": [
          {
            "reads": [
              {
                "forward": "forward-row1-first",
                "reverse": "reverse-row1-first"
              },
              {
                "forward": "forward-row1-last",
                "reverse": "reverse-row1-last"
              }
            ]
          },
          {
            "reads": [
              {
                "forward": "forward-row2-first",
                "reverse": "reverse-row2-first"
              },
              {
                "forward": "forward-row2-last",
                "reverse": "reverse-row2-last"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 75605101
  },
  {
    "context": [
      "But I want to find an object through **username** and set this object in the first index into the array. I want to find this object whose user name is **motalib**.",
      "Expected output:",
      "\"Post_Comment\": [\n             {\n                \"comment\": \"best\",\n                \"user\": {\n                    \"username\": \"motalib\"\n                },\n            },\n            {\n                \"comment\": \"nice\",\n                \"user\": {\n                    \"username\": \"sahed\"\n                },\n            },\n            {\n                \"comment\": \"nice.\",\n                \"user\": {\n                    \"username\": \"admin\"\n                },\n            }\n        ]",
      "if you want to swap them you can do:\n```\nconst users = Post_Comment\nconst idx = users.findIndex(r=>r.user.username === username)\n[users[0], users[idx]] = [users[idx], users[0]]\n```\n\nIf you want to add it to the beginning while moving other elements indexes you can do:\n```\nconst users = Post_Comment\nconst idx = users.findIndex(r=>r.user.username === username)\nusers.unshift(...users.splice(idx, 1))\n```"
    ],
    "utterance": "Move the object with user.username equal to \"motalib\" to the first position in the Post_Comment array, preserving the order of the remaining elements.",
    "expressions": [
      ".Post_Comment |= ([.[] | select(.user.username==\"motalib\")] + [.[] | select(.user.username!=\"motalib\")])"
    ],
    "data": [
      {
        "input": {
          "Post_Comment": [
            {
              "comment": "nice",
              "user": {
                "username": "sahed"
              }
            },
            {
              "comment": "best",
              "user": {
                "username": "motalib"
              }
            },
            {
              "comment": "nice.",
              "user": {
                "username": "admin"
              }
            }
          ]
        },
        "output": {
          "Post_Comment": [
            {
              "comment": "best",
              "user": {
                "username": "motalib"
              }
            },
            {
              "comment": "nice",
              "user": {
                "username": "sahed"
              }
            },
            {
              "comment": "nice.",
              "user": {
                "username": "admin"
              }
            }
          ]
        }
      }
    ],
    "identifier": 75613848
  },
  {
    "context": [
      "I need to remove the last three elements of this array.",
      "So this is what I did so far:",
      "`echo '{ \"tags\": [ \"2.9.7\", \"2.9.8\", \"2.9.9\", \"2.9.10\", \"2.9.11\", \"2.9.12\" ]}' | jq -r '.tags | sort[:3][]'`",
      "gives me `2.9.10 2.9.11 2.9.12`, but need it the other way round. These values should be removed, so the result should be:",
      "`2.9.7 2.9.8 2.9.9`",
      "Start the index counter at the third-last element `[-3`, and go until the end `:]`:",
      "\u2026 | jq -r '.tags | sort[-3:][ ]'",
      "If you want to sort the array by version numbers (structured as seen), split them at the dot into an array, convert the items into numbers, and sort by that:",
      "\u2026 | jq -r '.tags | sort_by(split(\".\") | map(tonumber))[:3][]'"
    ],
    "utterance": "List all elements except the last three from the sorted array of version tags.",
    "expressions": [
      ".tags | sort[:-3][]",
      ".tags | sort_by(split(\".\") | map(tonumber))[:-3][]"
    ],
    "data": [
      {
        "input": {
          "tags": [
            "2.9.7",
            "2.9.8",
            "2.9.9",
            "2.9.10",
            "2.9.11",
            "2.9.12"
          ]
        },
        "output": [
          "2.9.7",
          "2.9.8",
          "2.9.9"
        ]
      }
    ],
    "identifier": 75619786
  },
  {
    "context": [
      "You could bind `.city.sunrise` to a variable and use it later:",
      "jq -r '.city.sunrise as $sunrise | .list[] | select(.dt > $sunrise) | .clouds.all'",
      "You can bind `.city.sunrise` to a variable in the filter itself.",
      "curl ... | jq -r '.city.sunrise as $sr | .list[] | select(.dt > $sr) | .clouds.all | add'"
    ],
    "utterance": "Select all .clouds.all values from .list elements where .dt is greater than the value in .city.sunrise, by binding .city.sunrise to a variable within the query.",
    "expressions": [
      ".city.sunrise as $sunrise | .list[] | select(.dt > $sunrise) | .clouds.all"
    ],
    "identifier": 75620656
  },
  {
    "context": [
      "But `errors` is an optional value. If there is no error, the field is missing. How do I have to handle the optional value correctly in `jq`?",
      "So in the example the result is `message` and if there is no error, the result is empty.",
      "Alternatively, use the alternative operator `//` which is triggered on `null` or `false` (see the [manual](https://stedolan.github.io/jq/manual/#Alternativeoperator%3A%2F%2F)):",
      "\u2026 | jq -r '.errors[0].message // \"no errors\"'",
      "If your code would run into an exception, you can also equip the test with the error suppression operator `?`",
      "\u2026 | jq -r '(.errors[0].message)? // \"no errors\"'",
      "As @SUTerliakov pointed out, you can use `empty` anywhere in these examples instead of (the dummy string) `\"no errors\"` if you want no result at all on success."
    ],
    "utterance": "Output the first message from the errors array if it exists; otherwise, output nothing.",
    "expressions": [
      ".errors[0].message // empty",
      "(.errors[0].message)? // empty"
    ],
    "data": [
      {
        "input": {
          "errors": [
            {
              "code": "INVALID",
              "message": "message"
            }
          ]
        },
        "output": "message"
      },
      {
        "input": {},
        "output": ""
      }
    ],
    "identifier": 75620085
  },
  {
    "context": [
      "aws elb describe-load-balancers |\\\n   jq '.LoadBalancerDescriptions[] |\n       select(.DNSName == \"internal-elbdnsendpoint1.us-east-1.elb.amazonaws.com\") |\n       .LoadBalancerName, .SecurityGroups[]'",
      "aws elb describe-load-balancers |\\\n    jq -r --arg var $i '.LoadBalancerDescriptions[] | select(.DNSName == $var) | ...';",
      "I tried with \"$var\", $var and [$var]. doesn't work anything at select(.DNSName == $var)"
    ],
    "utterance": "For each DNS name in a list, select the load balancer with that DNSName and output its LoadBalancerName and all SecurityGroups.",
    "expressions": [
      ".LoadBalancerDescriptions[] | select(.DNSName == $var) | .LoadBalancerName, .SecurityGroups[]"
    ],
    "identifier": 75622802
  },
  {
    "context": [
      "One thing that I was missing is to get the log output of $FAILED_TESTS as text by piping as `jq -sR '. | @text'`",
      "I suggest to not use shell string interpolation to generate JSON; instead use `jq` directly to produce your expected output document:",
      "xq -r '.testsuites.testsuite.testcase[] | select(.failure)' < JUnitReport.xml \\",
      "| jq -sR '{ body: . }'"
    ],
    "utterance": "Convert arbitrary text from standard input into a JSON object with a field named body containing that text as a string.",
    "expressions": [
      "jq -sR '{ body: . }'"
    ],
    "identifier": 75624951
  },
  {
    "context": [
      "I would like to also exclude names that contain \"Failed\" or \"temp\" which would return the following:\n\nE180TH-426-CIC-008\nLBRTY-185-CIC-005",
      "how can I filter out names that contain \"ZZZ\" or \"Failed\" or \"temp\"?",
      "I'd go with select (which emits empty if its argument evaluates to false, i.e. there is no match), and test for regular expressions:\n```sh\njq '.players[].name | select(test(\"ZZZ|temp|Failed\") | not) '\n```",
      "\"E180TH-426-CIC-008\"\n\"LBRTY-185-CIC-005\""
    ],
    "utterance": "List all player names that do not contain \"ZZZ\", \"Failed\", or \"temp\".",
    "expressions": [
      ".players[].name | select(test(\"ZZZ|temp|Failed\") | not)"
    ],
    "data": [
      {
        "input": {
          "players": [
            {
              "name": "ZZZ-104TH-082-ADV-004"
            },
            {
              "name": "ZZZ-149TH-435-ADV-WL-006"
            },
            {
              "name": "GDS-123-CIC-007_temp-blocked"
            },
            {
              "name": "LRMR-121-CIC-002_temp-removed"
            },
            {
              "name": "NOS-343-CIC-003_Failed"
            },
            {
              "name": "E180TH-426-CIC-008"
            },
            {
              "name": "LBRTY-185-CIC-005"
            }
          ]
        },
        "output": [
          "E180TH-426-CIC-008",
          "LBRTY-185-CIC-005"
        ]
      }
    ],
    "identifier": 75630714
  },
  {
    "context": [
      "Is there a way that I can insert the .InstanceId from outside the array into the array, leaving me with:",
      "[.InstanceId] + (.Entries[] | [.ApplicationType, .Name, .Version, .PackageId, .Publisher, .URL, .Summary])"
    ],
    "utterance": "Prepend the value of InstanceId to each array containing ApplicationType, Name, Version, PackageId, Publisher, URL, and Summary from Entries.",
    "expressions": [
      "[.InstanceId] + (.Entries[] | [.ApplicationType, .Name, .Version, .PackageId, .Publisher, .URL, .Summary])"
    ],
    "data": [
      {
        "input": {
          "TypeName": "AWS:Application",
          "InstanceId": "i-0af68a7cf857bd010",
          "SchemaVersion": "1.1",
          "CaptureTime": "2023-03-01T16:28:43Z",
          "Entries": [
            {
              "ApplicationType": "admin",
              "Architecture": "x86_64",
              "Name": "accountsservice",
              "PackageId": "accountsservice_0.6.45-1ubuntu1.3_amd64.deb",
              "Publisher": "Ubuntu Developers <ubuntu-devel-discuss@lists.ubuntu.com>",
              "Summary": "query and manipulate user account information",
              "URL": "https://www.freedesktop.org/wiki/Software/AccountsService/",
              "Version": "0.6.45-1ubuntu1.3"
            }
          ]
        },
        "output": [
          "i-0af68a7cf857bd010",
          "admin",
          "accountsservice",
          "0.6.45-1ubuntu1.3",
          "accountsservice_0.6.45-1ubuntu1.3_amd64.deb",
          "Ubuntu Developers <ubuntu-devel-discuss@lists.ubuntu.com>",
          "https://www.freedesktop.org/wiki/Software/AccountsService/",
          "query and manipulate user account information"
        ]
      }
    ],
    "identifier": 75630084
  },
  {
    "context": [
      "I think my main issue I am running in, is that the 2th cpu element is a object, while the first cpu element is a array in JQ.",
      "I would like to have the following csv output",
      "jq -nr '\n  [\"unit-type\",\"unit-id\",\"cpu-id\",\"temperature\"] as $headers | $headers, (inputs\n    | [.[$headers[0,1]]] + (.cpu | arrays[], objects | [.[$headers[2,3]]])\n  ) | @csv\n'"
    ],
    "utterance": "Convert a stream of objects where the cpu field may be either an array or an object to a CSV where each line contains unit-type, unit-id, cpu-id, and temperature for every cpu entry.",
    "expressions": [
      "[\"unit-type\",\"unit-id\",\"cpu-id\",\"temperature\"] as $headers | $headers, (inputs | [.[$headers[0,1]]] + (.cpu | arrays[], objects | [.[$headers[2,3]]])) | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "unit-type": "amp",
            "unit-id": "0",
            "cpu": [
              {
                "cpu-id": "0",
                "temperature": "64(C)"
              },
              {
                "cpu-id": "1",
                "temperature": "64(C)"
              }
            ]
          },
          {
            "unit-type": "bcp",
            "unit-id": "1",
            "cpu": {
              "cpu-id": "0",
              "temperature": "74(C)"
            }
          }
        ],
        "output": "\"unit-type\",\"unit-id\",\"cpu-id\",\"temperature\"\n\"amp\",\"0\",\"0\",\"64(C)\"\n\"amp\",\"0\",\"1\",\"64(C)\"\n\"bcp\",\"1\",\"0\",\"74(C)\""
      }
    ],
    "identifier": 75638368
  },
  {
    "context": [
      "How can I get the first x levels of depth of an object and remove the rest using jq ?",
      "In my case, I want to get the 1st 3 levels (want to remove everything bellow location in all entries.",
      "jq 'delpaths([paths | select(length > 3)])'",
      "jq 'del(.[][][][])'",
      "def retain(depth):\n  if type == \"object\"\n  then if depth <= 0 then {}\n       else map_values(retain(depth - 1))\n       end\n  else .\n  end;\n\nretain(3)"
    ],
    "utterance": "Keep only the first 3 levels of objects and remove all nested content below the third level.",
    "expressions": [
      "delpaths([paths | select(length > 3)])",
      "del(.[][][][])",
      "def retain(depth): if type == \"object\" then if depth <= 0 then {} else map_values(retain(depth - 1)) end else . end; retain(3)"
    ],
    "data": [
      {
        "input": {
          "Service1": {
            "Production": {
              "Location 1": {
                "b2d1": {
                  "clusters": {
                    "Datacenter2": []
                  },
                  "prod": {
                    "clusters": {
                      "Datacenter1": []
                    }
                  }
                }
              },
              "Service2": {
                "Production": {
                  "Location 1": {
                    "dr1": {
                      "clusters": {
                        "Datacenter3": []
                      },
                      "prod": {
                        "clusters": {
                          "Datacenter1": []
                        }
                      }
                    }
                  }
                }
              }
            }
          }
        },
        "output": {
          "Service1": {
            "Production": {
              "Location 1": {},
              "Service2": {}
            }
          }
        }
      }
    ],
    "identifier": 75640739
  },
  {
    "context": [
      "However, I cannot seem to get `jq` to recursively go into the objects and set variables, so that `echo $services_pinger_dockerfile` gives `\"nodeapp\"` for example.",
      "I can convert to JSON using [`yq`][1], and then set the top level entries as variables with [`jq`][2]:",
      "eval $(yq e example.yaml -j | jq -r '..? | to_entries | .[] | .key + \"=\" + (.value|tostring)')"
    ],
    "utterance": "Produce bash variable assignments for all nested paths, such that each variable reflects the hierarchy using underscores, e.g., services_pinger_build_dockerfile for the value nodeapp.",
    "expressions": [
      "paths(scalars) as $p | [ $p | map(tostring) | join(\"_\") , getpath($p) ] | @tsv"
    ],
    "identifier": 75651078
  },
  {
    "context": [
      "I just want the .title, .url, .author.login, .reviews.author.login, .reviews.state and .mergedBy.login fields?",
      "how do I also limit the fields in the reviews array to author.login and state?",
      "map({ title: .title, URL: .url, author: .author.login, reviews: .reviews | map({ author: .author.login, state: .state }), \"merged by\": .mergedBy.login})",
      "map({ title, URL: .url, author: .author.login, reviews: (.reviews | map({ author: .author.login, state })), \"merged by\": .mergedBy.login})",
      "reviews: (.reviews | map({\"reviewed by\": .author.login, state}))",
      "map({ title: .title, URL: .url, author: .author.login, reviews: [(.reviews[] | with_entries(select(.key == \"author\" or .key == \"state\")) | .author=.author.login)], \"merged by\": .mergedBy.login})"
    ],
    "utterance": "Extract title, url, author (login), mergedBy (login), and reviews (with only author.login and state) from each object in the array.",
    "expressions": [
      "map({ title: .title, URL: .url, author: .author.login, reviews: (.reviews | map({ author: .author.login, state })), \"merged by\": .mergedBy.login})",
      "map({ title, URL: .url, author: .author.login, reviews: (.reviews | map({ author: .author.login, state })), \"merged by\": .mergedBy.login})",
      "map({ title, URL: .url, author: .author.login, reviews: (.reviews | map({ \"reviewed by\": .author.login, state })), \"merged by\": .mergedBy.login})",
      "[.[] | { title: .title, URL: .url, author: .author.login, reviews: [.reviews[] | { \"author\": .author.login, \"state\": .state }], \"merged by\": .mergedBy.login }]",
      "map({ title: .title, URL: .url, author: .author.login, reviews: [(.reviews[] | with_entries(select(.key == \"author\" or .key == \"state\")) | .author=.author.login)], \"merged by\": .mergedBy.login})"
    ],
    "data": [
      {
        "input": [
          {
            "author": {
              "id": "MDQ6VXNlcjYGJOYzNTIw",
              "is_bot": false,
              "login": "luke123",
              "name": "Luke"
            },
            "mergedAt": "2023-01-12T20:29:41Z",
            "mergedBy": {
              "id": "MDQ6VXNlcjYGJOYzNTIw",
              "is_bot": false,
              "login": "luke123",
              "name": "Luke"
            },
            "reviews": [
              {
                "id": "PRR_kwDODrt9D55KSvlh",
                "author": {
                  "login": "han123"
                },
                "authorAssociation": "CONTRIBUTOR",
                "body": "",
                "submittedAt": "2023-01-12T20:26:50Z",
                "includesCreatedEdit": false,
                "reactionGroups": [],
                "state": "APPROVED",
                "commit": {
                  "oid": "ff541b49775eab1ffc63www850dc405ecabc045f"
                }
              },
              {
                "id": "PRR_kwDODrt7OM8WHwat",
                "author": {
                  "login": "leia"
                },
                "authorAssociation": "CONTRIBUTOR",
                "body": "",
                "submittedAt": "2023-01-12T20:29:15Z",
                "includesCreatedEdit": false,
                "reactionGroups": [],
                "state": "APPROVED",
                "commit": {
                  "oid": "dd541b49775eab1ffc63bbb850dc405edhwc045c"
                }
              }
            ],
            "title": "Jedi Training",
            "url": "https://github.com/rebels/training/pull/222"
          }
        ],
        "output": [
          {
            "title": "Jedi Training",
            "URL": "https://github.com/rebels/training/pull/222",
            "author": "luke123",
            "reviews": [
              {
                "author": "han123",
                "state": "APPROVED"
              },
              {
                "author": "leia",
                "state": "APPROVED"
              }
            ],
            "merged by": "luke123"
          }
        ]
      }
    ],
    "identifier": 75605213
  },
  {
    "context": [
      "The field that I want to extract and format into csv is \r\n\"id\"\r\n\"type\"\r\n\r\nHow do I use linux jq commands to extract those?",
      "To extract these fields to csv, you can use `jq` with `@csv` filter in a shell script like this:",
      "fields=$(echo \"$json\" | jq -r '.results[] | [ .id, .type ] | @csv')",
      "Assuming the JSON provided in the example is valid (actually it's not, it seems to be truncated). You can get the expected CSV output using the `jq` query:",
      "jq --raw-output '[\"id\",\"type\"] as $headers | ($headers, (.results[] | [ .id, .type ])) | @csv' input.json"
    ],
    "utterance": "Extract only the fields id and type from each object in the results array and output as CSV.",
    "expressions": [
      ".results[] | [ .id, .type ] | @csv",
      "[\"id\",\"type\"] as $headers | ($headers, (.results[] | [ .id, .type ])) | @csv"
    ],
    "identifier": 75649776
  },
  {
    "context": [
      "He just wanted a single line with the max bid & min ask. In response, I produced the following jq abomination which works, but doesn't handle missing bids/asks at all:",
      "({} | {price,counterparty,quantity,allOrNothing,timestamp,orderId,implied}) as $fields\n| .orderbookSnapshotItem\n| [.exchange,.contract,.qtyDecimals, .contractTitle, .instrumentName]  as $common\n| ($common + (.bidPrice // [{}] | max_by(.price) | rec($fields)) + (.askPrice // [{}] | min_by(.price) | rec($fields)))?\n| @csv",
      "produces the following output:\n\"WhirlyGig\",\"OptimalSpring\",\"0\",\"Ancient Greek LPG - Apr23\",\"GDP\",\"47.205\",\"BiddyGig0\",\"10\",\"false\",\"2023-03-02T11:52:36.554Z\",\"0\",\"false\",,,,,,,,"
    ],
    "utterance": "Produce a single CSV record containing common fields and the highest-priced bid and lowest-priced ask, each with selected attributes, from an orderbookSnapshotItem.",
    "expressions": [
      "def rec($obj): . as $in | [$obj|keys_unsorted[] as $k | $in[$k]];\n({} | {price,counterparty,quantity,allOrNothing,timestamp,orderId,implied}) as $fields\n| .orderbookSnapshotItem\n| [.exchange,.contract,.qtyDecimals, .contractTitle, .instrumentName]  as $common\n| ($common + (.bidPrice // [{}] | max_by(.price) | rec($fields)) + (.askPrice // [{}] | min_by(.price) | rec($fields)))?\n| @csv"
    ],
    "data": [
      {
        "input": {
          "?xml": {
            "@version": "1.0",
            "@encoding": "UTF-8",
            "@standalone": "yes"
          },
          "orderbookSnapshotItem": {
            "exchange": "WhirlyGig",
            "contract": "OptimalSpring",
            "bidPrice": [
              {
                "price": "47.205",
                "counterparty": "BiddyGig0",
                "quantity": "10",
                "allOrNothing": "false",
                "timestamp": "2023-03-02T11:52:36.554Z",
                "orderId": "0",
                "implied": "false"
              },
              {
                "price": "47.200",
                "counterparty": "BiddyGig1",
                "quantity": "5",
                "allOrNothing": "false",
                "timestamp": "2023-03-02T11:52:36.554Z",
                "orderId": "0",
                "implied": "false"
              }
            ],
            "qtyDecimals": "0",
            "contractTitle": "Ancient Greek LPG - Apr23",
            "instrumentName": "GDP"
          }
        },
        "output": "\"WhirlyGig\",\"OptimalSpring\",\"0\",\"Ancient Greek LPG - Apr23\",\"GDP\",\"47.205\",\"BiddyGig0\",\"10\",\"false\",\"2023-03-02T11:52:36.554Z\",\"0\",\"false\",,,,,,,,"
      }
    ],
    "identifier": 75622260
  },
  {
    "context": [
      "echo null | jq '[{\"a\": null}, {\"a\": [1]}][] | select(has(\"a\")?) | .a[]'",
      "echo null | jq '[{\"a\": null}, {\"a\": [1]}][] | .a[]'",
      "`select(has(\"a\")?)`",
      "Recall that `E?` is shorthand for `try E catch empty`, hence the title of the bug report:",
      "It's as though the `catch` clause is misplaced:",
      "try (select(has(\"a\")) | .a[]) catch empty"
    ],
    "utterance": "After selecting objects where the key 'a' exists, extract each element of 'a', expecting that entries where 'a' is null will not produce an error.",
    "expressions": [
      "[{\"a\": null}, {\"a\": [1]}][] | select(has(\"a\")?) | .a[]",
      "try (select(has(\"a\")) | .a[]) catch empty"
    ],
    "data": [
      {
        "input": [
          {
            "a": null
          },
          {
            "a": [
              1
            ]
          }
        ],
        "output": [
          1
        ]
      }
    ],
    "identifier": 75655062
  },
  {
    "context": [
      "I want to pass an argument of space separated elements to jq and filter only these elements that have names matching to one of the argument elements.",
      "jq --arg names 'a c' '.[] | select(any(.name == ($names / \" \")[]; .))'",
      "jq -r --arg names 'a c' '($names/\" \") as $names | .[] | select(.name | IN($names[]))'"
    ],
    "utterance": "Return only the objects from the input whose name field matches any of the space-separated strings provided as an argument.",
    "expressions": [
      ".[] | select(any(.name == ($names / \" \")[]; .))",
      "($names/\" \") as $names | .[] | select(.name | IN($names[]))"
    ],
    "data": [
      {
        "input": [
          {
            "val": 1,
            "name": "a"
          },
          {
            "val": 2,
            "name": "b"
          },
          {
            "val": 3,
            "name": "c"
          }
        ],
        "output": [
          {
            "val": 1,
            "name": "a"
          },
          {
            "val": 3,
            "name": "c"
          }
        ]
      }
    ],
    "identifier": 75660442
  },
  {
    "context": [
      "I need to extract all the `name` properties of the `configMapRef`",
      "But I need to get the `name` so my output looks like this:\r\ndb-mssql-asd-connection\r\ndb-postgre-asd-connection\r\napp-url",
      "jq -r '.spec.template.spec.containers[].envFrom[].configMapRef.name // empty' file.json",
      "jq -r '.spec.template.spec.containers[].envFrom[].configMapRef.name | values' file.json",
      "jq -r '.spec.template.spec.containers[].envFrom[].configMapRef.name | strings' file.json",
      "$ jq -r '.spec.template.spec.containers[].envFrom[] | select(has(\"configMapRef\")).configMapRef.name' file.json",
      "$ jq -r '.spec.template.spec.containers[].envFrom[].configMapRef|select( . != null )|.name' file.json"
    ],
    "utterance": "Extract all values of the name property from every configMapRef inside the envFrom arrays of each container under spec.template.spec.containers.",
    "expressions": [
      ".spec.template.spec.containers[].envFrom[].configMapRef.name // empty",
      ".spec.template.spec.containers[].envFrom[].configMapRef.name | values",
      ".spec.template.spec.containers[].envFrom[].configMapRef.name | strings",
      ".spec.template.spec.containers[].envFrom[] | select(has(\"configMapRef\")).configMapRef.name",
      ".spec.template.spec.containers[].envFrom[].configMapRef|select( . != null )|.name"
    ],
    "data": [
      {
        "input": {
          "apiVersion": "apps/v1",
          "kind": "Deployment",
          "metadata": {
            "annotations": {
              "deployment.kubernetes.io/revision": "1"
            },
            "creationTimestamp": "2023-02-22T17:35:22Z",
            "generation": 1,
            "labels": {
              "app": "addresses",
              "group": "de.test",
              "provider": "jkube",
              "version": "2.3.0-3191"
            },
            "name": "addresses",
            "namespace": "linkerd",
            "resourceVersion": "910972",
            "uid": "aaee0eb0-5d66-44dd-b9b0-35e17bec4cf4"
          },
          "spec": {
            "progressDeadlineSeconds": 600,
            "replicas": 1,
            "revisionHistoryLimit": 2,
            "selector": {
              "matchLabels": {
                "app": "addresses",
                "group": "de.test",
                "provider": "jkube"
              }
            },
            "strategy": {
              "rollingUpdate": {
                "maxSurge": 1,
                "maxUnavailable": "50%"
              },
              "type": "RollingUpdate"
            },
            "template": {
              "metadata": {
                "annotations": {
                  "jkube.io/git-branch": "develop",
                  "jkube.io/git-commit": "77aaca38564dffff0ce10a8c70d4139b33f677b2",
                  "jkube.io/git-url": "http://bitbucket.org/testzentrale/test-monorepo",
                  "jkube.io/scm-tag": "HEAD",
                  "jkube.io/scm-url": "https://bitbucket.org/testzentrale/test-monorepo/test/addresses"
                },
                "creationTimestamp": null,
                "labels": {
                  "app": "addresses",
                  "group": "de.test",
                  "provider": "jkube",
                  "version": "2.3.0-3191"
                },
                "namespace": "test-testing"
              },
              "spec": {
                "containers": [
                  {
                    "env": [
                      {
                        "name": "SENTRY_ENVIRONMENT",
                        "valueFrom": {
                          "fieldRef": {
                            "apiVersion": "v1",
                            "fieldPath": "metadata.namespace"
                          }
                        }
                      },
                      {
                        "name": "SENTRY_SERVERNAME",
                        "valueFrom": {
                          "fieldRef": {
                            "apiVersion": "v1",
                            "fieldPath": "metadata.name"
                          }
                        }
                      },
                      {
                        "name": "SENTRY_TAGS",
                        "value": "service:addresses"
                      },
                      {
                        "name": "SENTRY_RELEASE",
                        "value": "2.3.0-3191"
                      },
                      {
                        "name": "JAVA_OPTIONS",
                        "value": "-Xms64m -Xmx384m"
                      },
                      {
                        "name": "KUBERNETES_NAMESPACE",
                        "valueFrom": {
                          "fieldRef": {
                            "apiVersion": "v1",
                            "fieldPath": "metadata.namespace"
                          }
                        }
                      },
                      {
                        "name": "HOSTNAME",
                        "valueFrom": {
                          "fieldRef": {
                            "apiVersion": "v1",
                            "fieldPath": "metadata.name"
                          }
                        }
                      }
                    ],
                    "envFrom": [
                      {
                        "configMapRef": {
                          "name": "db-mssql-asd-connection"
                        }
                      },
                      {
                        "secretRef": {
                          "name": "db-mssql-asd-connection"
                        }
                      },
                      {
                        "configMapRef": {
                          "name": "db-postgre-asd-connection"
                        }
                      },
                      {
                        "secretRef": {
                          "name": "db-postgre-asd-connection"
                        }
                      },
                      {
                        "configMapRef": {
                          "name": "app-url"
                        }
                      },
                      {
                        "secretRef": {
                          "name": "app-token"
                        }
                      }
                    ],
                    "image": "myrepo/test/addresses:testing-2.3.0-3191",
                    "imagePullPolicy": "IfNotPresent",
                    "livenessProbe": {
                      "failureThreshold": 3,
                      "httpGet": {
                        "path": "/",
                        "port": 8080,
                        "scheme": "HTTP"
                      },
                      "initialDelaySeconds": 300,
                      "periodSeconds": 10,
                      "successThreshold": 1,
                      "timeoutSeconds": 1
                    },
                    "name": "spring-boot",
                    "ports": [
                      {
                        "containerPort": 8080,
                        "name": "http",
                        "protocol": "TCP"
                      },
                      {
                        "containerPort": 9779,
                        "name": "prometheus",
                        "protocol": "TCP"
                      },
                      {
                        "containerPort": 8778,
                        "name": "jolokia",
                        "protocol": "TCP"
                      }
                    ],
                    "readinessProbe": {
                      "failureThreshold": 2,
                      "httpGet": {
                        "path": "/actuator/health",
                        "port": 8080,
                        "scheme": "HTTP"
                      },
                      "initialDelaySeconds": 20,
                      "periodSeconds": 10,
                      "successThreshold": 1,
                      "timeoutSeconds": 1
                    },
                    "resources": {
                      "limits": {
                        "memory": "1000Mi"
                      },
                      "requests": {
                        "cpu": "100m",
                        "memory": "500Mi"
                      }
                    },
                    "securityContext": {
                      "privileged": false
                    },
                    "terminationMessagePath": "/dev/termination-log",
                    "terminationMessagePolicy": "File",
                    "volumeMounts": [
                      {
                        "mountPath": "/deployments/config",
                        "name": "config"
                      }
                    ]
                  }
                ],
                "dnsPolicy": "ClusterFirst",
                "restartPolicy": "Always",
                "schedulerName": "default-scheduler",
                "securityContext": {},
                "terminationGracePeriodSeconds": 30,
                "volumes": [
                  {
                    "configMap": {
                      "defaultMode": 420,
                      "items": [
                        {
                          "key": "application.properties",
                          "path": "application.properties"
                        }
                      ],
                      "name": "addresses"
                    },
                    "name": "config"
                  }
                ]
              }
            }
          },
          "status": {
            "conditions": [
              {
                "lastTransitionTime": "2023-02-22T17:35:23Z",
                "lastUpdateTime": "2023-02-22T17:35:23Z",
                "message": "Deployment does not have minimum availability.",
                "reason": "MinimumReplicasUnavailable",
                "status": "False",
                "type": "Available"
              },
              {
                "lastTransitionTime": "2023-02-22T17:45:24Z",
                "lastUpdateTime": "2023-02-22T17:45:24Z",
                "message": "ReplicaSet \"addresses-dd575cdc9\" has timed out progressing.",
                "reason": "ProgressDeadlineExceeded",
                "status": "False",
                "type": "Progressing"
              }
            ],
            "observedGeneration": 1,
            "replicas": 1,
            "unavailableReplicas": 1,
            "updatedReplicas": 1
          }
        },
        "output": [
          "db-mssql-asd-connection",
          "db-postgre-asd-connection",
          "app-url"
        ]
      }
    ],
    "identifier": 75536682
  },
  {
    "context": [
      "I need to exclude field `_class` from this output:",
      "Result must be just:",
      "{\n  \"displayName\": \"NAME-(#1498)\",\n  \"number\": 1498\n}",
      "You can simply delete that field using `del`:",
      "\u2026 | jq '.builds[] | select(.displayName | contains(\"NAME\")) | del(._class)'"
    ],
    "utterance": "Exclude the field _class from each object in the builds array where displayName contains NAME.",
    "expressions": [
      ".builds[] | select(.displayName | contains(\"NAME\")) | del(._class)"
    ],
    "data": [
      {
        "input": {
          "builds": [
            {
              "_class": "hudson.model.FreeStyleBuild",
              "displayName": "NAME-(#1498)",
              "number": 1498
            },
            {
              "_class": "hudson.model.FreeStyleBuild",
              "displayName": "OTHER-(#1500)",
              "number": 1500
            }
          ]
        },
        "output": {
          "displayName": "NAME-(#1498)",
          "number": 1498
        }
      }
    ],
    "identifier": 75661787
  },
  {
    "context": [
      "What I want to do is add a field to each service while I loop over them with the http_response, so the JSON will be like:",
      "{ \"service10\": { \"path_to_file\" : \"service10.txt\", \"http_response\": 200 }, \"service192\": { \"path_to_file\" : \"service192.txt\", \"http_response\": 404 } }",
      "jq -r 'to_entries[] | [.key, .value.path_to_file] | @tsv' <\"$JSON_TO_READ\" \\",
      "| jq -Rn --slurpfile input_file \"$JSON_TO_READ\" '\n    reduce inputs as $inline\n      ($input_file[0];\n       (($inline | split(\"\\t\")) as $pieces |\n        .[$pieces[0]].http_response = ($pieces[1])))'",
      "for i in $(seq \"$length\"); do\n  entry=\"$(jq --argjson idx \"$i\" 'to_entries[$idx-1]' \"$input\")\"\n  path=\"$(printf '%s' \"$entry\" | jq -r '.value.path_to_file')\"\n  last_status_code=\"$(curl ... \"$path\")\"\n  printf '%s' \"$entry\" | jq --argjson status \"$last_status_code\" '.value.http_response = $status'\ndone | jq -s 'from_entries'"
    ],
    "utterance": "Add a field named http_response to each object in the top-level mapping, with its value set based on external shell command output accessed during iteration.",
    "expressions": [
      "jq -r 'to_entries[] | [.key, .value.path_to_file] | @tsv' <\"$JSON_TO_READ\" | while IFS=$'\\t' read -r key value; do http_status=$(curl ...); printf '%s\\t%s\\n' \"$key\" \"$http_status\"; done | jq -Rn --slurpfile input_file \"$JSON_TO_READ\" 'reduce inputs as $inline ($input_file[0]; (($inline | split(\"\\t\")) as $pieces | .[$pieces[0]].http_response = ($pieces[1])))'",
      "input='input.json'\nlength=\"$(jq 'length' \"$input\")\"\nfor i in $(seq \"$length\"); do\n  entry=\"$(jq --argjson idx \"$i\" 'to_entries[$idx-1]' \"$input\")\"\n  path=\"$(printf '%s' \"$entry\" | jq -r '.value.path_to_file')\"\n  last_status_code=\"$(curl ... \"$path\")\"\n  printf '%s' \"$entry\" | jq --argjson status \"$last_status_code\" '.value.http_response = $status'\ndone | jq -s 'from_entries'"
    ],
    "data": [
      {
        "input": {
          "service10": {
            "path_to_file": "service10.txt"
          },
          "service192": {
            "path_to_file": "service192.txt"
          }
        },
        "output": {
          "service10": {
            "path_to_file": "service10.txt",
            "http_response": 200
          },
          "service192": {
            "path_to_file": "service192.txt",
            "http_response": 404
          }
        }
      }
    ],
    "identifier": 75653903
  },
  {
    "context": [
      "How can I use `jq` to extract all JavaScript `<script>` tags from `html` using `pup`?",
      "I would like to put all of these extracted scripts in a new resulting json:",
      "it's not possible directly from jq (jq cannot call external programs from within a jq program). But if your input only contains a single object with those two properties, the following should work in POSIX shells:",
      "Use `json{}` instead of `text{}` to enable post-processing with jq. For example:",
      "jq '.scripts = (input | map(.text // empty))' \"$jsonfile\" <(\n  jq -r '.html' \"$jsonfile\" | pup 'script[type=text/javascript] json{}'\n)"
    ],
    "utterance": "Extract all scripts of type text/javascript from the html property and insert them as an array under the scripts key, preserving the original url.",
    "expressions": [
      "jq '.scripts = (input | map(.text // empty))' \"$jsonfile\" <(jq -r '.html' \"$jsonfile\" | pup 'script[type=text/javascript] json{}')"
    ],
    "data": [
      {
        "input": {
          "url": "https://www.example.com",
          "html": "<html><head><script type=\"text/javascript\">var a = 1;</script><script type=\"text/javascript\">var b = 2;</script></head><body></body></html>"
        },
        "output": {
          "url": "https://www.example.com",
          "html": "<html><head><script type=\"text/javascript\">var a = 1;</script><script type=\"text/javascript\">var b = 2;</script></head><body></body></html>",
          "scripts": [
            "var a = 1;",
            "var b = 2;"
          ]
        }
      }
    ],
    "identifier": 75661161
  },
  {
    "context": [
      "I want to do the same thing like above but with using two variables:",
      "VAR1=\"a1\"",
      "VAR2=\"b1\"",
      "jq --arg v1 \"$VAR1\" --arg v2 \"$VAR2\" '.[$v1].[$v2]' data.json",
      "Drop the inner dot:",
      "jq --arg v1 \"$VAR1\" --arg v2 \"$VAR2\" '.[$v1][$v2]' data.json"
    ],
    "utterance": "Extract the value at the path defined by two shell variables, where the first is 'a1' and the second is 'b1'.",
    "expressions": [
      ".[$v1][$v2]"
    ],
    "data": [
      {
        "input": {
          "a1": {
            "b1": {
              "key1": "value1",
              "key2": "value2"
            }
          }
        },
        "output": {
          "key1": "value1",
          "key2": "value2"
        }
      }
    ],
    "identifier": 75690570
  },
  {
    "context": [
      "I have some json data that looks like:",
      "I want to convert it to:",
      "{\n    \"a1\": {\n        \"b1\": {},\n        \"b2\": {}\n    },\n    \"a2\": {\n        \"b3\": {},\n        \"b4\": {}\n    }\n}",
      "If you just want to set all items on second level to an empty object, use:",
      "jq '.[][] = {}' some.json",
      "Note: map_values is defined as def map_values(f): .[] |= f;, so .[][] = {} is effectively the same as map_values(map_values({}))"
    ],
    "utterance": "Replace all second-level objects in the data with empty objects, preserving the top two levels of keys.",
    "expressions": [
      ".[][] = {}",
      "map_values(map_values({}))"
    ],
    "data": [
      {
        "input": {
          "a1": {
            "b1": {
              "c1": {},
              "c2": []
            },
            "b2": {
              "c3": {},
              "c4": []
            }
          },
          "a2": {
            "b3": {
              "c5": {},
              "c6": []
            },
            "b4": {
              "c7": {},
              "c8": []
            }
          }
        },
        "output": {
          "a1": {
            "b1": {},
            "b2": {}
          },
          "a2": {
            "b3": {},
            "b4": {}
          }
        }
      }
    ],
    "identifier": 75679671
  },
  {
    "context": [
      "Here is a sample of the JSON:\n\n``` json\n{\n  \"Defaults\": {\n    \"Timestamps\": [\n      1677801540,\n      1677801480,\n      1677801420\n    ]\n  },\n  \"MetricDataForAccount\": [\n    {\n      \"Values\": [\n        2920126.416862745,\n        2920285.9993725484,\n        2920305.409303922\n      ]\n    }\n  ]\n}\n```",
      "The intended goal would be for the output to looks as follows:\n\n``` csv\n1677801540, 2920126.416862745\n1677801480, 2920285.9993725484\n1677801420, 2920305.409303922\n```",
      "You could `transpose` the arrays to align their items:\n```sh\njq -r '[.Defaults.Timestamps, .MetricDataForAccount[].Values] | transpose[] | @csv'\n```",
      "Or iterate manually (e.g. using `to_entries` to access the indices as `.key`):\n```sh\njq -r '\n  .Defaults.Timestamps as $timestamps\n  | .MetricDataForAccount[].Values\n  | to_entries[] | [$timestamps[.key], .value]\n  | @csv\n'\n```",
      "Output:\n```\n1677801540,2920126.416862745\n1677801480,2920285.9993725484\n1677801420,2920305.409303922\n```"
    ],
    "utterance": "Produce rows that pair each timestamp with the corresponding value, formatted as CSV, such that each output line contains a timestamp and its matching value from two separate arrays.",
    "expressions": [
      "[.Defaults.Timestamps, .MetricDataForAccount[].Values] | transpose[] | @csv",
      ".Defaults.Timestamps as $timestamps | .MetricDataForAccount[].Values | to_entries[] | [$timestamps[.key], .value] | @csv"
    ],
    "data": [
      {
        "input": {
          "Defaults": {
            "Timestamps": [
              1677801540,
              1677801480,
              1677801420
            ]
          },
          "MetricDataForAccount": [
            {
              "Values": [
                2920126.416862745,
                2920285.9993725484,
                2920305.409303922
              ]
            }
          ]
        },
        "output": [
          "1677801540,2920126.416862745",
          "1677801480,2920285.9993725484",
          "1677801420,2920305.409303922"
        ]
      }
    ],
    "identifier": 75679431
  },
  {
    "context": [
      "I want to create a new structure from it that looks like this:",
      "{\n  \"source\": [\n    \"# Get the files in a directory \\n\",\n    \"ls -l \\n\"\n  ],\n  \"title\": \"# Get the files in a directory \\n\"\n}\n{\n  \"source\": [\n    \"# Get the files in a directory \\n\",\n    \"ls -l \\n\"\n  ],\n  \"title\": \"# Get the working directory \\n\"\n}\n{\n  \"source\": [\n    \"# Get the files in a directory \\n\",\n    \"ls -l \\n\"\n  ],\n  \"title\": \"# Get the network config \\n\"\n}",
      "cat test.json | jq '{source: .cells[].source, title: .cells[].source[0] }'",
      "I'm getting duplicate records in the output.",
      ".cells[] | {source, title: .source[0]}",
      "It will assign the first item in `.source` to the (new) property `.title` of each cell",
      "The output for all 3 programs is:\n\n{\n  \"source\": [\n    \"# Get the files in a directory \\n\",\n    \"ls -l \\n\"\n  ],\n  \"title\": \"# Get the files in a directory \\n\"\n}\n{\n  \"source\": [\n    \"# Get the working directory \\n\",\n    \"pwd \\n\"\n  ],\n  \"title\": \"# Get the working directory \\n\"\n}\n{\n  \"source\": [\n    \"# Get the network config \\n\",\n    \"ipconfig \\n\"\n  ],\n  \"title\": \"# Get the network config \\n\"\n}"
    ],
    "utterance": "Output each object in the cells array with its source property and a new title field set to the first element of source.",
    "expressions": [
      ".cells[] | {source, title: .source[0]}",
      ".cells[] | .title = .source[0]",
      ".cells[] | . + {title: .source[0]}"
    ],
    "data": [
      {
        "input": {
          "cells": [
            {
              "source": [
                "# Get the files in a directory \n",
                "ls -l \n"
              ]
            },
            {
              "source": [
                "# Get the working directory \n",
                "pwd \n"
              ]
            },
            {
              "source": [
                "# Get the network config \n",
                "ipconfig \n"
              ]
            }
          ],
          "metadata": {
            "kernelspec": {
              "display_name": "Bash",
              "language": "bash",
              "name": "bash"
            }
          }
        },
        "output": [
          {
            "source": [
              "# Get the files in a directory \n",
              "ls -l \n"
            ],
            "title": "# Get the files in a directory \n"
          },
          {
            "source": [
              "# Get the working directory \n",
              "pwd \n"
            ],
            "title": "# Get the working directory \n"
          },
          {
            "source": [
              "# Get the network config \n",
              "ipconfig \n"
            ],
            "title": "# Get the network config \n"
          }
        ]
      }
    ],
    "identifier": 75667634
  },
  {
    "context": [
      "I am trying to use JQ to parse the values from the **compare** list (.query.compare[]) and the results. Getting the results has been an issue as the key values are the same parameters as the values in the **compare** list.",
      "How do I use the values from the compare list to perform a match that can be used to extract the values from the respective keys in the **results** section?",
      "You can use the `.query.compare` array to select from `.results` like this:",
      "$ cat example.json | jq '.results[.query.compare[]]'",
      "To show the compare and results separately, we can use the syntax from above:",
      "$ cat example.json | jq '{compare: .query.compare, results: [.results[.query.compare[]]]}'"
    ],
    "utterance": "Extract the values from the results object using each value in the compare list as a key and output them as an array.",
    "expressions": [
      ".results[.query.compare[]]",
      "[.results[.query.compare[]]]",
      "{compare: .query.compare, results: [.results[.query.compare[]]]}"
    ],
    "data": [
      {
        "input": {
          "query": {
            "unit": "km",
            "code": "10005",
            "country": "us",
            "compare": [
              "10006",
              "10007"
            ]
          },
          "results": {
            "10006": 0.54,
            "10007": 0.93
          }
        },
        "output": [
          0.54,
          0.93
        ]
      }
    ],
    "identifier": 75692242
  },
  {
    "context": [
      "Not able to convert it to Prometheus format using jq or any other better approach to capture the metrics on Prometheus UI.",
      "Maybe something like this?",
      "```jq\npaths(scalars) as $p \n| \"\\($p|join(\"_\")|gsub(\"[^\\\\w_.-]\";\"\"))=\\(getpath($p)|@sh)\"\n```",
      "```shell-session\n$ jq -r 'paths(scalars) as $p | \"\\($p|join(\"_\")|gsub(\"[^\\\\w_.-]\";\"\"))=\\(getpath($p)|@sh)\"' file.json"
    ],
    "utterance": "Flatten the nested data so each scalar value is output as a key-value pair formatted like 'key1_key2_key3=VALUE', suitable for ingestion by Prometheus.",
    "expressions": [
      "paths(scalars) as $p | \"\\($p|join(\"_\")|gsub(\"[^\\\\w_.-]\";\"\"))=\\(getpath($p)|@sh)\""
    ],
    "data": [
      {
        "input": {
          "version": "3.0.0",
          "gauges": {
            "gc.G1-Old-Generation.count": {
              "value": 0
            },
            "gc.G1-Old-Generation.time": {
              "value": 0
            }
          },
          "counters": {
            "counter": {
              "count": 1
            }
          }
        },
        "output": [
          "version='3.0.0'",
          "gauges_gc.G1-Old-Generation.count_value=0",
          "gauges_gc.G1-Old-Generation.time_value=0",
          "counters_counter_count=1"
        ]
      }
    ],
    "identifier": 75660722
  },
  {
    "context": [
      "This is what I&#39;m using to pretty-print json (calling the jq command):",
      "(system (string-append \"echo \\\"\" str_clean \"\\\" | jq .\")))",
      "Ideally I would like to not have to depend on jq, I just want to be able to display a json with indentation and spaces.",
      "; Start a jq child process to format the JSON.",
      "(find-executable-path \"jq\") \"--unbuffered\" \".\""
    ],
    "utterance": "Display a data structure with indentation and spaces so it is easy to read.",
    "expressions": [
      "jq ."
    ],
    "data": [
      {
        "input": [
          1,
          2,
          3,
          4
        ],
        "output": [
          1,
          2,
          3,
          4
        ]
      }
    ],
    "identifier": 75706374
  },
  {
    "context": [
      "trans=$(openai api completions.create -m text-davinci-003 -p 'Translate '\"$(xclip -o -sel c)\"' into English.' | jq -r '.choices[0].text')",
      "echo \"$trans\" always returns the following error: \"parse error: Invalid numeric literal at line 1, column 10\"",
      "I believe you can get a JSON responSE by specifying the \"Content-Type\" header as \"application/json\" in the API request."
    ],
    "utterance": "Extract the text field of the first element in choices from the OpenAI API completion response.",
    "expressions": [
      ".choices[0].text"
    ],
    "identifier": 75718295
  },
  {
    "context": [
      "I am getting correct output but with characters not recognized by the system.",
      "Output of jq:\n\u001b[1;39m{\n  \u001b[0m\u001b[34;1m\"test\"\u001b[0m\u001b[1;39m: \u001b[0m\u001b[0;32m\"data\"\u001b[0m\u001b[1;39m\n\u001b[1;39m}\u001b[0m",
      "How can I get an output file without extra characters ?",
      "The -M command-line option suppresses the kind of extra characters you mention.",
      "If you want complete control over the STDOUT output, consider using the -c and -j command-line options, which together suppress everything that isn't explicitly sent to STDOUT."
    ],
    "utterance": "Remove color codes and extra characters from the output to produce plain text.",
    "expressions": [
      "jq -M .",
      "jq --monochrome-output ."
    ],
    "identifier": 75717572
  },
  {
    "context": [
      "$get_snap=$(curl -s \"https://opens.endpoint.com/_snapshot\" | jq -e '[.[].settings.bucket][1]')",
      "So, I want to perform a condition to check if $get_snap is equal to \"staging-opens-snap\" :",
      "if curl ... | jq -e '[.[].settings.bucket][1] == \"staging-opens-snap\"'; then",
      "result=$(curl ... | jq -r 'if [.[].settings.bucket][1] == \"staging-opens-snap\"\n then \"is same\"\n else \"is different\"\n end')"
    ],
    "utterance": "Check if the second value in all objects' settings.bucket arrays is equal to staging-opens-snap.",
    "expressions": [
      "[.[].settings.bucket][1] == \"staging-opens-snap\"",
      "if [.[].settings.bucket][1] == \"staging-opens-snap\" then \"is same\" else \"is different\" end"
    ],
    "identifier": 75720639
  },
  {
    "context": [
      "As you can see the name variable is \"job_get_re_log\" but the name in the json is \"job_get_re_Log\" (capital L). This ends up failing and returning nothing because it's looking for an exact match.",
      "How can I modify the select command so it compares without considering the case (case insensitive)?",
      "To use `test/1` to check for equality ignoring case, you would have to anchor the regex string.  Assuming $name has no special regex characters:",
      "jq -r --arg w \"$workspace\" --arg e \"$environment\" --arg n \"$name\" '\n  .items[]\n  | select( (.name | test(\"^\\($n)$\"; \"i\")) and\n            (.workspace.name == $w) and\n            (.workspace.environment.name == $e)) \n  | .id'"
    ],
    "utterance": "Select the id of the item where the name matches a given value case-insensitively, and workspace and environment names match exactly.",
    "expressions": [
      ".items[] | select((.name | test(\"^\\($n)$\"; \"i\")) and (.workspace.name == $w) and (.workspace.environment.name == $e)) | .id"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "id": "some_id_1",
              "name": "job_get_re_Log",
              "type": "standard",
              "workspace": {
                "id": "some_id_2",
                "name": "Shared",
                "description": "",
                "type": "custom",
                "environment": {
                  "id": "some_id_3",
                  "name": "DEV"
                }
              }
            }
          ]
        },
        "output": "some_id_1"
      }
    ],
    "identifier": 75699001
  },
  {
    "context": [
      "I figured I could simply do another select statement to get the IP, but this causes a complete whiff:",
      "\u279c  cat event.json | jq '[.evidence[] | {upn: select(.\"@odata.type\" == \"#microsoft.graph.security.userEvidence\") | .userAccount.userPrincipalName, ip: select(.\"@odata.type\" == \"#microsoft.graph.security.ipEvidence\") | .ipAddress }]'",
      "[]",
      "\"How might I accomplish this? Why are my current attempts unsuccessful?\"",
      "Therefore, you need to iterate for each of those parts separately in order to retrieve the matching ones: `.evidence | \u2026 [] \u2026 [] \u2026`.",
      ".evidence | {\n  upn: (.[] | select(.\"@odata.type\" == \"#microsoft.graph.security.userEvidence\").userAccount.userPrincipalName),\n  ip: (.[] | select(.\"@odata.type\" == \"#microsoft.graph.security.ipEvidence\").ipAddress)\n}",
      ".evidence | INDEX(.\"@odata.type\") as $e | {\n  upn: $e[\"#microsoft.graph.security.userEvidence\"].userAccount.userPrincipalName,\n  ip: $e[\"#microsoft.graph.security.ipEvidence\"].ipAddress\n}"
    ],
    "utterance": "Produce an object with the user principal name from the userEvidence entry and the ipAddress from the ipEvidence entry in the evidence array.",
    "expressions": [
      ".evidence | { upn: (.[] | select(.\"@odata.type\" == \"#microsoft.graph.security.userEvidence\").userAccount.userPrincipalName), ip: (.[] | select(.\"@odata.type\" == \"#microsoft.graph.security.ipEvidence\").ipAddress) }",
      ".evidence | INDEX(.\"@odata.type\") as $e | { upn: $e[\"#microsoft.graph.security.userEvidence\"].userAccount.userPrincipalName, ip: $e[\"#microsoft.graph.security.ipEvidence\"].ipAddress }"
    ],
    "data": [
      {
        "input": {
          "id": "<redacted>",
          "providerAlertId": "<redacted>",
          "incidentId": "<redacted>",
          "status": "new",
          "severity": "low",
          "classification": null,
          "determination": null,
          "serviceSource": "microsoftDefenderForCloudApps",
          "detectionSource": "cloudAppSecurity",
          "detectorId": "MCAS_ALERT_ANUBIS_DETECTION_REPEATED_ACTIVITY_FAILED_LOGIN",
          "tenantId": "<redacted>",
          "title": "Multiple failed login attempts",
          "description": "The user <redacted> (<redacted>) performed more than 51 failed logins attempts in a single session.",
          "recommendedActions": "",
          "category": "CredentialAccess",
          "assignedTo": null,
          "alertWebUrl": "https://security.microsoft.com/alerts/<redacted>?tid=<redacted>",
          "incidentWebUrl": "https://security.microsoft.com/incidents/<redacted>?tid=6<redacted>",
          "actorDisplayName": null,
          "threatDisplayName": null,
          "threatFamilyName": null,
          "mitreTechniques": [
            "T1110",
            "T1110.001"
          ],
          "createdDateTime": "2023-03-01T18:13:38.812686Z",
          "lastUpdateDateTime": "2023-03-01T18:14:46.6766667Z",
          "resolvedDateTime": null,
          "firstActivityDateTime": "2023-03-01T17:56:52.145Z",
          "lastActivityDateTime": "2023-03-01T17:58:11.708Z",
          "comments": [],
          "evidence": [
            {
              "@odata.type": "#microsoft.graph.security.userEvidence",
              "createdDateTime": "2023-03-01T18:13:38.8966667Z",
              "verdict": "unknown",
              "remediationStatus": "none",
              "remediationStatusDetails": null,
              "roles": [],
              "tags": [],
              "userAccount": {
                "accountName": "<redacted>",
                "domainName": null,
                "userSid": "<redacted>",
                "azureAdUserId": "<redacted>",
                "userPrincipalName": "<redacted>"
              }
            },
            {
              "@odata.type": "#microsoft.graph.security.cloudApplicationEvidence",
              "createdDateTime": "2023-03-01T18:13:38.8966667Z",
              "verdict": "unknown",
              "remediationStatus": "none",
              "remediationStatusDetails": null,
              "roles": [],
              "tags": [],
              "appId": 11161,
              "displayName": "Office 365",
              "instanceId": 0,
              "instanceName": null,
              "saasAppId": 11161
            },
            {
              "@odata.type": "#microsoft.graph.security.cloudApplicationEvidence",
              "createdDateTime": "2023-03-01T18:13:38.8966667Z",
              "verdict": "unknown",
              "remediationStatus": "none",
              "remediationStatusDetails": null,
              "roles": [],
              "tags": [],
              "appId": 28375,
              "displayName": "Microsoft Teams",
              "instanceId": 0,
              "instanceName": null,
              "saasAppId": 28375
            },
            {
              "@odata.type": "#microsoft.graph.security.ipEvidence",
              "createdDateTime": "2023-03-01T18:13:38.8966667Z",
              "verdict": "unknown",
              "remediationStatus": "none",
              "remediationStatusDetails": null,
              "roles": [
                "attacker"
              ],
              "tags": [],
              "ipAddress": "<redacted>",
              "countryLetterCode": null
            }
          ]
        },
        "output": {
          "upn": "<redacted>",
          "ip": "<redacted>"
        }
      }
    ],
    "identifier": 75623166
  },
  {
    "context": [
      "how can I output the same JSON structure, but with only the first N elements in `mylist`?",
      "I was trying to use `jq '.mylist[:N]'`, but this prints the first N elements of `mylist` without the other fields such as `foo`.",
      "jq '.mylist = (.mylist[:N])'",
      "jq '.mylist |= .[:N]'"
    ],
    "utterance": "Return the full input object but with the 'mylist' field truncated to its first N elements.",
    "expressions": [
      ".mylist = (.mylist[:N])",
      ".mylist |= .[:N]"
    ],
    "data": [
      {
        "input": {
          "mylist": [
            1,
            2,
            3,
            4,
            5
          ],
          "foo": "bar"
        },
        "output": {
          "mylist": [
            1,
            2,
            3
          ],
          "foo": "bar"
        }
      }
    ],
    "identifier": 75730078
  },
  {
    "context": [
      "Then I have a string `x` with value `ThiS.FIle.is.HeRe`, now I wanted to know whether any of the string in the array matched the substring in `x`, case-insensitive (`true`/`false` result).",
      "Use `inside` (the reverse operation to `contains`) on strings with unified case (e.g. `ascii_downcase`). `any` will evaluate to `true` if at least one item matches.",
      "jq --arg x 'ThiS.FIle.is.HeRe' 'any(.[] | ascii_downcase; inside($x | ascii_downcase))'"
    ],
    "utterance": "Determine if any value in an array is a case-insensitive substring of a given string and return true or false.",
    "expressions": [
      "any(.[] | ascii_downcase; inside($x | ascii_downcase))"
    ],
    "data": [
      {
        "input": [
          "This.FilE",
          "That.file",
          "Another.FIle"
        ],
        "output": true
      }
    ],
    "identifier": 75732475
  },
  {
    "context": [
      "But I need to decode the entire database keys and values to human readable format?",
      "If the encoded data is a string and not binary data, you can decode it to a UTF-8 string using the `@base64d` filter. This should be available in jq 1.6.",
      "this one command work for me in etcd v3:",
      "etcdctl get \"\" --prefix -w json | jq -r '\n  .kvs[] |\n  {key: (.key | @base64d), value: (.value | @base64d)}\n'"
    ],
    "utterance": "Extract all items and return objects with both 'key' and 'value' fields base64-decoded",
    "expressions": [
      ".kvs[] | {key: (.key | @base64d), value: (.value | @base64d)}",
      ".[][] | (.key, .value) |= @base64d"
    ],
    "data": [
      {
        "input": {
          "kvs": [
            {
              "key": "YnktZGV2L21ldGEvc25hcHNob3RzL3Jvb3QtY29vcmQvcGFydGl0aW9ucy80NDAwNDc0MjQ2MTgzNjUxNzAvNDQwMDQ3NDI0NjE4MzY1MTcxX3RzNDQwMDQ5NDg5ODkxODE5NTI0",
              "create_revision": 44536,
              "mod_revision": 44536,
              "version": 1,
              "value": "CPOB0OXRmdeNBhIIX2RlZmF1bHQYhIDgxN/V140GIPKB0OXRmdeNBg=="
            }
          ]
        },
        "output": {
          "key": "by-dev/meta/snapshots/root-coord/partitions/440047424618365170/440047424618365171_ts440049489891819524",
          "value": "\b\ufffd\u000e\u007fNd\u007f]\u001d \b_default\u0018\ufffd1\u007fTf\u001d\ufffd\b\u001c\u001f\ndev\u0006"
        }
      }
    ],
    "identifier": 75721086
  },
  {
    "context": [
      ".DashboardSummaryList[] | select(.Name|contains(\"$e\")) | .DashboardId",
      "You are checking if `.Name` contains the literal string `$e`; the variable does not need to be quoted.",
      "... select(.Name|contains($e)) | ..."
    ],
    "utterance": "Get all DashboardId values where Name contains the provided entity string.",
    "expressions": [
      ".DashboardSummaryList[] | select(.Name | contains($e)) | .DashboardId"
    ],
    "identifier": 75744676
  },
  {
    "context": [
      "I have a json value that can contain a single record or an array, I need to extract the ID field of these records and gather them in an array. The resulting element should be an array with 1 or more ID values.",
      "Input 1  Single record",
      "{ \"CVE\": { \"ID\": \"CVE-2022-26138\",\"URL\": \"foo.bar\" } }",
      "Input 2  An array of two records",
      "{ \"CVE\": [ { \"ID\": \"CVE-2019-2969\",\"URL\": \"foo.com\" }, { \"ID\": \"CVE-2019-3030\",\"URL\": \"bar.com\" } ] }",
      "By using the filters `objects` and `arrays`, you can handle different types differently, like here using `.[]` only on arrays. Then, using `-n` and `inputs` lets you access multiple input objects at once, thus collect their values into a single final array.",
      "jq -n '[inputs.CVE | objects, arrays[] | .ID]'"
    ],
    "utterance": "Extract the ID field from the CVE property, whether it contains a single object or an array of objects, and collect all ID values into an array.",
    "expressions": [
      "[.CVE | objects, arrays[] | .ID]",
      "jq -n '[inputs.CVE | objects, arrays[] | .ID]'"
    ],
    "data": [
      {
        "input": {
          "CVE": {
            "ID": "CVE-2022-26138",
            "URL": "foo.bar"
          }
        },
        "output": [
          "CVE-2022-26138"
        ]
      },
      {
        "input": {
          "CVE": [
            {
              "ID": "CVE-2019-2969",
              "URL": "foo.com"
            },
            {
              "ID": "CVE-2019-3030",
              "URL": "bar.com"
            }
          ]
        },
        "output": [
          "CVE-2019-2969",
          "CVE-2019-3030"
        ]
      }
    ],
    "identifier": 75727365
  },
  {
    "context": [
      "If I hard code like this `inside([\"test, coverage\"])` then my code works fine. However if I try to put it dynamically using variable called jobs_to_copy then it throws error.",
      "If you see the echo statement (`echo $jobs_to_copy`), it does print in this required format [\"test\",\"coverage\"] but not sure why this error is still coming then.",
      "jq: error: jobs_to_copy/0 is not defined at <top-level>, line 1:\n    .[] | select(([.name] | inside($jobs_to_copy)) and .artifacts_file != null) | .id",
      "If you want `$jobs_to_copy` to be substituted with the variable value, don't use single quotes but rather double quotes.",
      "In your case, that'd look like this:\n```bash\nJOBS=$(cat jobs.json | jq '.[] | select(([.name] | inside('\"$jobs_to_copy\"')) and .artifacts_file != null) | .id')\n```"
    ],
    "utterance": "Select records where .name is in the dynamic array held by the shell variable jobs_to_copy and .artifacts_file is not null.",
    "expressions": [
      ".[] | select(([.name] | inside($jobs_to_copy)) and .artifacts_file != null) | .id",
      ".[] | select(([.name] | inside(",
      "'.[] | select(([.name] | inside('\"$jobs_to_copy\"')) and .artifacts_file != null) | .id'"
    ],
    "identifier": 75753671
  },
  {
    "context": [
      "The end goal is to get the `quota limits` from GCP that have non-default values.",
      "the expected output would be something like this",
      "[{\"metric\": \"compute.googleapis.com/a2_cpus\",\"quota\": [{\"defaultLimit\": \"12\",\"dimensions\": {\"region\": \"asia-east1\"},\"effectiveLimit\": \"13\"}]}]",
      "map(.quota |= map(select(.defaultLimit != .effectiveLimit)) | select(.quota | length > 0))",
      "To keep only the limits and dimensions (dropping producerOverride and any other additional properties):",
      "map(.quota |= map(select(.defaultLimit != .effectiveLimit) | {defaultLimit, effectiveLimit, dimensions}) | select(.quota | length > 0))",
      "map(.quota |= map(select(.defaultLimit != .effectiveLimit) | del(.producerOverride)) | select(.quota | length > 0))"
    ],
    "utterance": "List all quota entries where defaultLimit is not equal to effectiveLimit, preserving only the metric and those quota entries, and omitting any metrics without such quota entries.",
    "expressions": [
      "map(.quota |= map(select(.defaultLimit != .effectiveLimit)) | select(.quota | length > 0))",
      "map(.quota |= map(select(.defaultLimit != .effectiveLimit) | {defaultLimit, effectiveLimit, dimensions}) | select(.quota | length > 0))",
      "map(.quota |= map(select(.defaultLimit != .effectiveLimit) | del(.producerOverride)) | select(.quota | length > 0))"
    ],
    "data": [
      {
        "input": [
          {
            "metric": "compute.googleapis.com/a2_cpus",
            "quota": [
              {
                "defaultLimit": "-1",
                "effectiveLimit": "-1"
              }
            ]
          },
          {
            "metric": "compute.googleapis.com/a2_cpus",
            "quota": [
              {
                "defaultLimit": "12",
                "effectiveLimit": "12"
              },
              {
                "defaultLimit": "12",
                "dimensions": {
                  "region": "asia-east1"
                },
                "effectiveLimit": "13",
                "producerOverride": {
                  "dimensions": {
                    "region": "asia-east1"
                  }
                }
              }
            ]
          }
        ],
        "output": [
          {
            "metric": "compute.googleapis.com/a2_cpus",
            "quota": [
              {
                "defaultLimit": "12",
                "dimensions": {
                  "region": "asia-east1"
                },
                "effectiveLimit": "13"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 75740548
  },
  {
    "context": [
      "I want to to iterate over the objects and get a **unique list** of names.",
      "**In this example, the desired output** would be `[\"Dallas\", \"New York\"]`",
      "jq '.Items | map(.LOCATION.NAME) | unique'"
    ],
    "utterance": "Get a unique list of all LOCATION.NAME values from an array of objects under the Items key.",
    "expressions": [
      ".Items | map(.LOCATION.NAME) | unique"
    ],
    "data": [
      {
        "input": {
          "Items": [
            {
              "LOCATION": {
                "NAME": "Dallas"
              }
            },
            {
              "LOCATION": {
                "NAME": "New York"
              }
            },
            {
              "LOCATION": {
                "NAME": "Dallas"
              }
            }
          ]
        },
        "output": [
          "Dallas",
          "New York"
        ]
      }
    ],
    "identifier": 75760433
  },
  {
    "context": [
      "The command `find . -name 'reddit.*.flattened.json' | jq '.'` gives the error `parse error: Invalid numeric literal at line 2, column 0`.",
      "I can load each file with `jq` by typing `jq '.' FILENAME` so there is no error in the files.",
      "you could use the anti-pattern:\n\n    jq . $(find \u2026\u2026)",
      "Let `find` do it, instead of having the shell stick its nose in the middle.\n\n    find . -name 'reddit.*.flattened.json' -exec jq '.' {} \\;"
    ],
    "utterance": "Process all files found in the current directory and subdirectories matching 'reddit.*.flattened.json' by applying the identity filter to each.",
    "expressions": [
      "jq . $(find . -name 'reddit.*.flattened.json')",
      "find . -name 'reddit.*.flattened.json' -exec jq '.' {} \\;",
      "find . -name 'reddit.*.flattened.json' -exec jq '.' {} +"
    ],
    "data": [
      {
        "input": [
          "./reddit.opiates.flattened.json",
          "./reddit.OurOverUsedVeins.flattened.json",
          "./reddit.microdosing.flattened.json",
          "./reddit.naloxone.flattened.json",
          "./reddit.suboxone.flattened.json",
          "./reddit.heroin.flattened.json",
          "./reddit.OpiatesRecovery.flattened.json",
          "./reddit.fentanyl.flattened.json"
        ]
      }
    ],
    "identifier": 75757712
  },
  {
    "context": [
      "Is it possible to use the jq has() function with nested keys?",
      "Not directly, but you can descend to that level, and use `has` for the last one:",
      "jq '(.a | has(\"b\"))' <<< '{\"a\":{\"b\":\"hello\"}}'",
      "Alternatively, search the `paths` for the one you are looking for, converted to array notation:",
      "jq 'IN(paths; [\"a\",\"b\"])' <<< '{\"a\":{\"b\":\"hello\"}}'",
      "you could use `getpath/1`, either by itself or wrapped in an `if`, e.g.",
      "getpath([\"a\",\"b\"]) | if . == null then false else true end"
    ],
    "utterance": "Determine if an object contains the nested key path a.b",
    "expressions": [
      ".a | has(\"b\")",
      "IN(paths; [\"a\",\"b\"])",
      "getpath([\"a\",\"b\"]) | if . == null then false else true end"
    ],
    "data": [
      {
        "input": {
          "a": {
            "b": "hello"
          }
        },
        "output": true
      },
      {
        "input": {
          "a": {
            "c": "world"
          }
        },
        "output": false
      }
    ],
    "identifier": 75769972
  },
  {
    "context": [
      "Suppose we have the following JSON - `{a:1,b:\"x\"}`. I want to extract the properties `a` and `b` and assign them to the respective bash variables.",
      "For the purpose of this post, use this json:\n{\n  \"a\": 1,\n  \"b\": \"x y\"\n}\nBut the solution should work equally well for a JSON with 50 top level properties.",
      "eval $(jq -r 'to_entries|map(\"export \\(.key)=\\\"\\(.value|tostring)\\\"\")|.[]' file.json)",
      "{ while read -r dec; do declare \"$dec\"; done; } < <(jq -r 'to_entries[] | join(\"=\")' file.json)",
      "source <(jq -r 'to_entries[]|\"export \\(.key)=\\\"\\(.value)\\\"\"' <<<'{\"a\":1,\"b\":\"x y z\"}')"
    ],
    "utterance": "Extract all top-level properties from an object, and output them as key-value assignments suitable for use as shell variables, correctly handling values with spaces.",
    "expressions": [
      "jq -r 'to_entries | map(\"export \\(.key)=\\\"\\(.value|tostring)\\\"\") | .[]' file.json",
      "jq -r 'to_entries[] | join(\"=\")' file.json",
      "jq -r 'to_entries[]|\"export \\(.key)=\\\"\\(.value)\\\"\"' file.json"
    ],
    "data": [
      {
        "input": {
          "a": 1,
          "b": "x y"
        },
        "output": [
          "export a=\"1\"",
          "export b=\"x y\""
        ]
      }
    ],
    "identifier": 75779596
  },
  {
    "context": [
      "I want it to look like this:\r\n\r\n```\r\n{\r\n    \"name\": \"My Team\",\r\n    \"team size\": [\r\n        {\r\n            \"size\": \"min\",\r\n            \"Leader\": 1,\r\n            \"Followers\": 5,\r\n            \"point cost\": 7\r\n        },\r\n        {\r\n            \"size\": \"max\",\r\n            \"Leader\": 1,\r\n            \"Followers\": 9,\r\n            \"point cost\": 11\r\n        }\r\n    ]\r\n}\r\n```",
      "Here&#39;s one of many ways:\r\n```\r\n.[\"team size\"] |=\r\n  (add\r\n   | [ ({size: \"min\"} + (.min | add)),\r\n       ({size: \"max\"} + (.max | add)) ] )\r\n```",
      "or more DRYly:\r\n```\r\n.[\"team size\"] |=\r\n  (add\r\n   | . as $in\r\n   | reduce keys_unsorted[] as $k ([];\r\n       . + [{size: $k} + ($in[$k]|add) ] ))\r\n```"
    ],
    "utterance": "Reshape objects within the 'team size' array into flat objects with a 'size' field indicating 'min' or 'max', merging the nested fields accordingly.",
    "expressions": [
      ".[\"team size\"] |= (add | [ ({size: \"min\"} + (.min | add)), ({size: \"max\"} + (.max | add)) ])",
      ".[\"team size\"] |= (add | . as $in | reduce keys_unsorted[] as $k ([]; . + [{size: $k} + ($in[$k]|add) ] ))"
    ],
    "data": [
      {
        "input": {
          "name": "My Team",
          "team size": [
            {
              "min": [
                {
                  "Leader": 1
                },
                {
                  "Followers": 5
                },
                {
                  "point cost": 7
                }
              ]
            },
            {
              "max": [
                {
                  "Leader": 1
                },
                {
                  "Followers": 9
                },
                {
                  "point cost": 11
                }
              ]
            }
          ]
        },
        "output": {
          "name": "My Team",
          "team size": [
            {
              "size": "min",
              "Leader": 1,
              "Followers": 5,
              "point cost": 7
            },
            {
              "size": "max",
              "Leader": 1,
              "Followers": 9,
              "point cost": 11
            }
          ]
        }
      }
    ],
    "identifier": 75778883
  },
  {
    "context": [
      "I want to search for objects in the second array whereby the `name` field value is an element of the first array, and then add a field, say `\"found\": true`, to those objects.",
      ".[0] as $tn | .[1][] | select(.name | IN($tn[])) | .found = true",
      ".[0] as $tn | (.[1][] | select(.name | IN($tn[]))).found = true",
      "first as $names\n| .[1][] | select(.name|IN($names[]))\n| .found = true",
      "first as $names\n| (.[1][] | select(.name|IN($names[]))).found = true"
    ],
    "utterance": "For all objects in the second array whose name is in the first array, add the field found: true to those objects.",
    "expressions": [
      ".[0] as $tn | .[1][] | select(.name | IN($tn[])) | .found = true",
      ".[0] as $tn | (.[1][] | select(.name | IN($tn[]))).found = true",
      "first as $names | .[1][] | select(.name|IN($names[])) | .found = true",
      "first as $names | (.[1][] | select(.name|IN($names[]))).found = true"
    ],
    "data": [
      {
        "input": [
          [
            "test1",
            "test2",
            "test3"
          ],
          [
            {
              "name": "test5",
              "data": "five"
            },
            {
              "name": "test1",
              "data": "four"
            },
            {
              "name": "test2",
              "data": "three"
            },
            {
              "name": "test3",
              "data": "six"
            }
          ]
        ],
        "output": [
          {
            "name": "test1",
            "data": "four",
            "found": true
          },
          {
            "name": "test2",
            "data": "three",
            "found": true
          },
          {
            "name": "test3",
            "data": "six",
            "found": true
          }
        ]
      }
    ],
    "identifier": 75761115
  },
  {
    "context": [
      "I\u2019d like to transform this:\n```\n{\n  \"foo\": \"bar\",\n  \"baz\": \"qux\"\n}\n```\n\nInto this:\n```\n-var=\"foo=bar\" -var=\"baz=qux\"\n```\n",
      "But I can\u2019t figure out the last step to have it join them with a space instead of a new line.",
      "You can use the `join()` function in JQ to join the key/value pairs with a space instead of a new line.\n\n```\njq -r \". | to_entries | map(\\\"-var=\\\\\\\"\\(.key)=\\(.value)\\\\\\\"\\\") | join(\\\" \\\" )\"\n```",
      "You want `[ ... ] | join( \" \" )`.\n\n```sh\njq -r 'to_entries | map( \"-var=\\\"\\( .key + \"=\" + .value )\\\"\" ) | join( \" \" )'\n```",
      "But it looks like you\u2019re building a shell command, so you should also use `@sh` (or whatever\u2019s appropriate for the shell you use) to properly quote the values."
    ],
    "utterance": "Transform an object into a single string with each key and value joined as -var=\"key=value\" and all pairs separated by spaces.",
    "expressions": [
      ". | to_entries | map(\"-var=\\\"\\(.key)=\\(.value)\\\"\") | join(\" \")",
      "to_entries | map( \"-var=\\\"\\( .key + \"=\" + .value )\\\"\" ) | join( \" \" )",
      "to_entries | map( @sh \"-var=\\( .key + \"=\" + .value )\" ) | join( \" \" )"
    ],
    "data": [
      {
        "input": {
          "foo": "bar",
          "baz": "qux"
        },
        "output": "-var=\"foo=bar\" -var=\"baz=qux\""
      },
      {
        "input": {
          "foo": "bar",
          "baz": "qux",
          "moo": "a'b\"c"
        },
        "output": "-var='foo=bar' -var='baz=qux' -var='moo=a'\\''b\"c'"
      }
    ],
    "identifier": 75782530
  },
  {
    "context": [
      "I\u0019m interesting in:\r\n- extracting the id as a number\r\n- only elements with type = \"item\"\r\n- only if they have an English label\r\n- also extract any English aliases\r\n- only those that don\u0019t have a claim of key \"P31\" which contains a datavalue of Q13442814\r\n- output as tsv",
      "My current filter looks like this:\r\n\r\n`.[] | select((.type == \"item\") and (.labels | has(\"en\")) and (.claims.P31 // [] | map(.mainsnak.datavalue.value.id != \"Q13442814\") | all)) | (.id|ltrimstr(\"Q\")) as $id | .labels[\"en\"].value, (.aliases[\"en\"] // [] | map(.value))[] | [$id, .] | @tsv`",
      "That said, if a single item of your original input array *does* fit into your memory, you can use `fromstream(1|truncate_stream(inputs))` using `--stream` and the `-n` flag (for `inputs`), followed by your original filter (after `.[] |`) on the unstripped input array to access its items as you did before but without loading the whole document into memory:\r\n```sh\r\njq -rn --stream 'fromstream(1|truncate_stream(inputs)) | select(\u001a\u001a) | \u001a\u001a | @tsv'\r\n```"
    ],
    "utterance": "Extract id as a number, for elements where type is 'item', an English label exists, any English aliases, and no claim 'P31' contains datavalue 'Q13442814'; output as TSV.",
    "expressions": [
      ".[] | select((.type == \"item\") and (.labels | has(\"en\")) and (.claims.P31 // [] | map(.mainsnak.datavalue.value.id != \"Q13442814\") | all)) | (.id|ltrimstr(\"Q\")) as $id | .labels[\"en\"].value, (.aliases[\"en\"] // [] | map(.value))[] | [$id, .] | @tsv",
      "fromstream(1|truncate_stream(inputs)) | select((.type == \"item\") and (.labels | has(\"en\")) and (.claims.P31 // [] | map(.mainsnak.datavalue.value.id != \"Q13442814\") | all)) | (.id|ltrimstr(\"Q\")) as $id | .labels[\"en\"].value, (.aliases[\"en\"] // [] | map(.value))[] | [$id, .] | @tsv"
    ],
    "data": [
      {
        "input": {
          "id": "Q60",
          "type": "item",
          "aliases": {
            "en": [
              {
                "language": "en",
                "value": "NYC"
              },
              {
                "language": "en",
                "value": "New York"
              }
            ],
            "fr": [
              {
                "language": "fr",
                "value": "New York City"
              },
              {
                "language": "fr",
                "value": "NYC"
              }
            ]
          },
          "labels": {
            "en": {
              "language": "en",
              "value": "New York City"
            }
          },
          "claims": {
            "P625": [
              {
                "id": "q60$f00c56de-4bac-e259-b146-254897432868",
                "mainsnak": {
                  "snaktype": "value",
                  "property": "P625",
                  "datatype": "globe-coordinate",
                  "datavalue": {
                    "value": {
                      "latitude": 40.67,
                      "longitude": -73.94,
                      "altitude": null,
                      "precision": 0.00027777777777778,
                      "globe": "http://www.wikidata.org/entity/Q2"
                    },
                    "type": "globecoordinate"
                  }
                },
                "type": "statement",
                "rank": "normal",
                "references": [
                  {
                    "hash": "7eb64cf9621d34c54fd4bd040ed4b61a88c4a1a0",
                    "snaks": {
                      "P143": [
                        {
                          "snaktype": "value",
                          "property": "P143",
                          "datatype": "wikibase-item",
                          "datavalue": {
                            "value": {
                              "entity-type": "item",
                              "id": "Q328",
                              "numeric-id": 328
                            },
                            "type": "wikibase-entityid"
                          }
                        }
                      ]
                    },
                    "snaks-order": [
                      "P143"
                    ]
                  }
                ]
              }
            ]
          }
        },
        "output": [
          "60\tNew York City",
          "60\tNYC",
          "60\tNew York"
        ]
      }
    ],
    "identifier": 75694540
  },
  {
    "context": [
      "jq produces unexpected results when `any()` is called in this context `any(array[]==val)`",
      "$ jq -n '[2,2] | any( [1,2][]|. == .) '\nfalse",
      "$ jq -n '[2,2] | any( [2,1][]|. == .) '\nfalse",
      "$ jq -n '[2,2] | any( [1,2][] == .) '\ntrue",
      "$ jq -n '[2,2] | any( [2,1][] == .) '\nfalse",
      "It seems that is a bug in jq 1.6. I compiled master version which gives correct result :",
      "$ jq --version\njq-1.6-159-gcff5336",
      "$ jq -n '[2,2] | any( [1,2][]|. == .) '\ntrue",
      "$ jq -n '[2,2] | any( [2,1][]|. == .) '\ntrue",
      "$ jq -n '[2,2] | any( [1,2][] == .) '\ntrue",
      "$ jq -n '[2,2] | any( [2,1][] == .) '\ntrue"
    ],
    "utterance": "Check if any value in [2,2] matches any value in [2,1] using equality comparison for each combination.",
    "expressions": [
      "[2,2] | any([2,1][]; . == .)",
      "[2,2] | any([2,1][]|. == .)"
    ],
    "data": [
      {
        "input": [
          2,
          2
        ],
        "output": true
      }
    ],
    "identifier": 75785532
  },
  {
    "context": [
      "and would like a map of instance id (i1...) and the map it has associated like this:",
      "{\n    \"i1\": {\n        \"updated\": \"2023-03-19T17:45:03.703984279+01:00\",\n        \"chargePower\": 349.9999940395355\n    },\n    \"i2\": {\n        \"updated\": \"2023-02-10T18:34:56.352428175+01:00\",\n        \"chargePower\": 0\n    }\n}",
      ".clients | map(.instances) | add",
      "reduce .clients[].instances as $i ({}; . + $i)"
    ],
    "utterance": "Extract a single map where each key is an instance id and each value is its associated map, combining all instances from all clients.",
    "expressions": [
      ".clients | map(.instances) | add",
      "reduce .clients[].instances as $i ({}; . + $i)"
    ],
    "data": [
      {
        "input": {
          "version": 2,
          "clients": {
            "c1": {
              "updated": "0001-01-01T00:00:00Z",
              "instances": {
                "i1": {
                  "updated": "2023-03-19T17:45:03.703984279+01:00",
                  "chargePower": 349.9999940395355
                }
              }
            },
            "c2": {
              "updated": "0001-01-01T00:00:00Z",
              "instances": {
                "i2": {
                  "updated": "2023-02-10T18:34:56.352428175+01:00",
                  "chargePower": 0
                }
              }
            }
          }
        },
        "output": {
          "i1": {
            "updated": "2023-03-19T17:45:03.703984279+01:00",
            "chargePower": 349.9999940395355
          },
          "i2": {
            "updated": "2023-02-10T18:34:56.352428175+01:00",
            "chargePower": 0
          }
        }
      }
    ],
    "identifier": 75794207
  },
  {
    "context": [
      "I want to transform each JSON document like this:",
      "You could use `to_entries` to decompose the nested objects into `.key` and `.value`, then rearrange and update using `|=`:",
      "<file.json jq '.models |= map(to_entries[] | {\"model name\": .key} + .value)\n  | .models[].attacks |= map(to_entries[] | {\"attack name\": .key} + .value)'"
    ],
    "utterance": "Transform an object with arrays of single-key objects in 'models' and 'attacks' to arrays where the key becomes 'model name' or 'attack name' and the contents are merged at the top level.",
    "expressions": [
      ".models |= map(to_entries[] | {\"model name\": .key} + .value) | .models[].attacks |= map(to_entries[] | {\"attack name\": .key} + .value)"
    ],
    "data": [
      {
        "input": {
          "name": "Reeve Hunter",
          "edition": 3,
          "revision": "2021 v1",
          "keywords": [
            "Circle",
            "Wolf Sworn",
            "Reeve of Orboros",
            "Solo"
          ],
          "point cost": 4,
          "field allowance": 2,
          "models": [
            {
              "Hunter": {
                "spd": 6,
                "str": 6,
                "mat": 6,
                "rat": 7,
                "def": 13,
                "arm": 13,
                "cmd": 7,
                "boxes": 5,
                "advantages": [
                  "Advance Deploy",
                  "Assault",
                  "Pathfinder"
                ],
                "base size": 30,
                "attacks": [
                  {
                    "Double Crossbow": {
                      "type": "ranged",
                      "rng": 12,
                      "rof": 2,
                      "pow": 10
                    }
                  },
                  {
                    "Battle Blade": {
                      "type": "melee",
                      "rng": 0.5,
                      "pow": 3,
                      "p+s": 9
                    }
                  },
                  {
                    "Cleft Sword": {
                      "type": "melee",
                      "rng": 1,
                      "pow": 5,
                      "p+s": 11,
                      "weapon qualities": [
                        "Weapon Master"
                      ],
                      "abilities": [
                        "Powerful Charge"
                      ]
                    }
                  }
                ],
                "abilities": [
                  "Hunter",
                  "Leadership [Reeves of Orboros]",
                  "Quickwork",
                  "Sprint"
                ]
              }
            }
          ]
        },
        "output": {
          "name": "Reeve Hunter",
          "edition": 3,
          "revision": "2021 v1",
          "keywords": [
            "Circle",
            "Wolf Sworn",
            "Reeve of Orboros",
            "Solo"
          ],
          "point cost": 4,
          "field allowance": 2,
          "models": [
            {
              "model name": "Hunter",
              "spd": 6,
              "str": 6,
              "mat": 6,
              "rat": 7,
              "def": 13,
              "arm": 13,
              "cmd": 7,
              "boxes": 5,
              "advantages": [
                "Advance Deploy",
                "Assault",
                "Pathfinder"
              ],
              "base size": 30,
              "attacks": [
                {
                  "attack name": "Double Crossbow",
                  "type": "ranged",
                  "rng": 12,
                  "rof": 2,
                  "pow": 10
                },
                {
                  "attack name": "Battle Blade",
                  "type": "melee",
                  "rng": 0.5,
                  "pow": 3,
                  "p+s": 9
                },
                {
                  "attack name": "Cleft Sword",
                  "type": "melee",
                  "rng": 1,
                  "pow": 5,
                  "p+s": 11,
                  "weapon qualities": [
                    "Weapon Master"
                  ],
                  "abilities": [
                    "Powerful Charge"
                  ]
                }
              ],
              "abilities": [
                "Hunter",
                "Leadership [Reeves of Orboros]",
                "Quickwork",
                "Sprint"
              ]
            }
          ]
        }
      }
    ],
    "identifier": 75723659
  },
  {
    "context": [
      "I want to replace the value for `id` with a new one.",
      "And want to replace it with the variable app_id `app_id=6e663913-0000-3456-c083e40fbc99`",
      "the output should be [...] `id`: `6e663913-0000-3456-c083e40fbc99`",
      "jq --arg app_id \"$APP_ID\" '[].id = $app_id' oauth2-permissions.json"
    ],
    "utterance": "Replace each object's id field with the value 6e663913-0000-3456-c083e40fbc99 from a shell variable",
    "expressions": [
      "jq --arg app_id \"$APP_ID\" '.[].id = $app_id' oauth2-permissions.json"
    ],
    "data": [
      {
        "input": [
          {
            "adminConsentDescription": "default",
            "adminConsentDisplayName": "default",
            "id": "5ad89ced-56a1-2222-8200-1ded5129d788",
            "isEnabled": true,
            "type": "User",
            "userConsentDescription": null,
            "userConsentDisplayName": null,
            "value": "default"
          }
        ],
        "output": [
          {
            "adminConsentDescription": "default",
            "adminConsentDisplayName": "default",
            "id": "6e663913-0000-3456-c083e40fbc99",
            "isEnabled": true,
            "type": "User",
            "userConsentDescription": null,
            "userConsentDisplayName": null,
            "value": "default"
          }
        ]
      }
    ],
    "identifier": 75803143
  },
  {
    "context": [
      "how do I pretty-print",
      "I am also stuck with a hard-coded key `schema` key when there are other keys in my json with nested json and I don&#39;t know the names of those keys.",
      "Is there a way to do this generically for any key name that contains nested json without escaping the escapes or specifying the keys?",
      "You could `walk` through the document tree, `try` to convert `strings` using `fromjson`, and `catch` failures by falling back to the original item:",
      "`echo \u2026 | jq 'walk(strings = (. as $s | try fromjson catch $s))'`"
    ],
    "utterance": "Convert all string values that are valid nested object representations into objects at any key and pretty-print the result.",
    "expressions": [
      "walk(strings = (. as $s | try fromjson catch $s))",
      "walk(strings = (. as $s | try (fromjson | objects // $s) catch $s))"
    ],
    "data": [
      {
        "input": {
          "my_key": "my_val",
          "next_key": "next_val",
          "schema": "{\n  \"name\": \"bucket_name\"\n}"
        },
        "output": {
          "my_key": "my_val",
          "next_key": "next_val",
          "schema": {
            "name": "bucket_name"
          }
        }
      }
    ],
    "identifier": 75805361
  },
  {
    "context": [
      "I want to replace one of the values in the file.",
      "I can get it to change the output:\r\n    $ jq '.keyPairs[] | select(.key == \"second\") | .value.intValue = \"0\"' myfile.json",
      "But this just changes the output. How do I get the value in the file changed?",
      "Bring the assignment to top-level by enclosing traversal and filtering into parentheses, so the context stays the same on exit:",
      "jq '(.keyPairs[] | select(.key == \"second\").value.intValue) = \"0\"' myfile.json"
    ],
    "utterance": "Update intValue to \"0\" for the object in keyPairs where key equals \"second\".",
    "expressions": [
      "(.keyPairs[] | select(.key == \"second\").value.intValue) = \"0\""
    ],
    "data": [
      {
        "input": {
          "keyPairs": [
            {
              "key": "first",
              "value": {
                "boolValue": false
              }
            },
            {
              "key": "second",
              "value": {
                "intValue": "1"
              }
            }
          ]
        },
        "output": {
          "keyPairs": [
            {
              "key": "first",
              "value": {
                "boolValue": false
              }
            },
            {
              "key": "second",
              "value": {
                "intValue": "0"
              }
            }
          ]
        }
      }
    ],
    "identifier": 75806651
  },
  {
    "context": [
      "What I would like to do using jq, is see if there exists any key of Sub1, that contains the value val2.",
      "So in the above JSON-document, the output should yield true.",
      "You can use `any` to check items in a stream for a condition. If you first stream all leaf objects with `.[][][]`, then you can simply check the `Sub1` property for the expected value:",
      "any(.[][\"My$Val\"][]; .Sub1 == \"val2\")",
      "It is also possible to use the SQL-like `IN` operator to check if a stream of values contains a value:",
      "IN(.[][\"My$Val\"].Sub1; \"val2\")"
    ],
    "utterance": "Check if any Sub1 property equals val2 and return true or false.",
    "expressions": [
      "any(.[][\"My$Val\"][]; .Sub1 == \"val2\")",
      "IN(.[][\"My$Val\"][].Sub1; \"val2\")"
    ],
    "data": [
      {
        "input": [
          {
            "My$Val": [
              {
                "Sub1": "val1",
                "pld": "s"
              }
            ]
          },
          {
            "My$Val": [
              {
                "Sub1": "val2",
                "pld": "q"
              }
            ]
          }
        ],
        "output": true
      }
    ],
    "identifier": 75814612
  },
  {
    "context": [
      "from below json data i need to fetch only the block which satisfy my condition.",
      "I tried below but fetching all the fields",
      "`cat json_data | jq \".\" | jq 'select(.updated_on > 2023-01-17)'`",
      "Fortunately, strings can be compared lexicographically by jq which saves you from converting the strings to date objects first. You just need to make sure to actually use a string in the comparison:",
      "select(.updated_on > \"2023-01-17\")",
      "Filter date:",
      "$ cat json_data | jq -s 'map(select((.updated_on > \"2023-01-07\")))'",
      "$ cat json_data | jq -s 'map(select((.updated_on|gsub(\"T.*\";\"\") ==  \"2023-01-08\")))'"
    ],
    "utterance": "Filter objects to include only those with an updated_on value after 2023-01-17.",
    "expressions": [
      "select(.updated_on > \"2023-01-17\")",
      "map(select(.updated_on > \"2023-01-17\"))"
    ],
    "data": [
      {
        "input": [
          {
            "comment_count": 0,
            "task_count": 0,
            "type": "pullrequest",
            "id": 3,
            "title": "Fix/adding jacoco",
            "state": "MERGED",
            "reason": "",
            "created_on": "2023-02-08T05:17:49.292686+00:00",
            "updated_on": "2023-02-08T08:55:02.565205+00:00"
          },
          {
            "comment_count": 0,
            "task_count": 0,
            "type": "pullrequest",
            "id": 2,
            "title": "Fix/adding jacoco",
            "state": "MERGED",
            "reason": "",
            "created_on": "2023-01-08T05:17:49.292686+00:00",
            "updated_on": "2023-01-08T08:55:02.565205+00:00"
          },
          {
            "comment_count": 0,
            "task_count": 0,
            "type": "pullrequest",
            "id": 1,
            "title": "Fix/adding jacoco",
            "state": "MERGED",
            "reason": "",
            "created_on": "2022-02-08T05:17:49.292686+00:00",
            "updated_on": "2022-02-08T08:55:02.565205+00:00"
          }
        ],
        "output": [
          {
            "comment_count": 0,
            "task_count": 0,
            "type": "pullrequest",
            "id": 3,
            "title": "Fix/adding jacoco",
            "state": "MERGED",
            "reason": "",
            "created_on": "2023-02-08T05:17:49.292686+00:00",
            "updated_on": "2023-02-08T08:55:02.565205+00:00"
          }
        ]
      }
    ],
    "identifier": 75808800
  },
  {
    "context": [
      "I want to see each line where `country` is \"Canada\" and `rating` is 10 in the same object within the `demographic` array",
      "However, my goal is to have those two key value pairs in the **same** object",
      "The expected output is:",
      "`{\"id\": \"454FGF6\", \"demographic\": [{\"country\": \"Germany\", \"rating\": 4},{\"country\": \"Canada\", \"rating\": 10}]}`",
      "Use [`any()`][1] to check if *any* of the `demographic` match your logic:",
      "select(.demographic | any(.country == \"Spain\" and .rating == 7))"
    ],
    "utterance": "Return each item where any element in the demographic array has country equal to \"Canada\" and rating equal to 10 in the same object.",
    "expressions": [
      "select(.demographic | any(.country == \"Canada\" and .rating == 10))"
    ],
    "data": [
      {
        "input": {
          "id": "3DFD4GF",
          "demographic": [
            {
              "country": "Spain",
              "rating": 7
            },
            {
              "country": "Germany",
              "rating": 2
            }
          ]
        }
      },
      {
        "input": {
          "id": "454FGF6",
          "demographic": [
            {
              "country": "Germany",
              "rating": 4
            },
            {
              "country": "Canada",
              "rating": 10
            }
          ]
        },
        "output": {
          "id": "454FGF6",
          "demographic": [
            {
              "country": "Germany",
              "rating": 4
            },
            {
              "country": "Canada",
              "rating": 10
            }
          ]
        }
      }
    ],
    "identifier": 75813401
  },
  {
    "context": [
      "I have the following JSON:\n{\n  \"foo1\": \"bar1\",\n  \"foo2\": \"bar2\",\n  \"items\": [\n    {\n      \"name\": \"c1\",\n      \"version\": \"v1\",\n      \"foo\": \"bar\"\n    },\n    {\n      \"name\": \"c5\"\n    },\n    {\n      \"name\": \"c2\",\n      \"version\": \"v2\",\n      \"fooArr\": []\n    },\n    {\n      \"name\": \"c5\"\n    },\n    {\n      \"name\": \"c3\",\n      \"version\": \"v3\"\n    },\n    {\n      \"name\": \"c4\"\n    }\n  ],\n  \"foo3\": \"bar3\",\n  \"foo4\": \"bar4\"\n}",
      "I'm trying to convert it to below by adding default version to items and removing duplicates by name",
      ".items |= (group_by(.name) | map(first | . + { name, version: (.version // \"NA\") }))",
      "jq --argjson def '{\"version\": \"NA\"}' '.items |= (unique_by(.name) | map($def + .))'"
    ],
    "utterance": "For each object in items, set version to NA if missing, and remove duplicates by name while preserving all other fields.",
    "expressions": [
      ".items |= (group_by(.name) | map(first | . + { name, version: (.version // \"NA\") }))",
      "jq --argjson def '{\"version\": \"NA\"}' '.items |= (unique_by(.name) | map($def + .))'"
    ],
    "data": [
      {
        "input": {
          "foo1": "bar1",
          "foo2": "bar2",
          "items": [
            {
              "name": "c1",
              "version": "v1",
              "foo": "bar"
            },
            {
              "name": "c5"
            },
            {
              "name": "c2",
              "version": "v2",
              "fooArr": []
            },
            {
              "name": "c5"
            },
            {
              "name": "c3",
              "version": "v3"
            },
            {
              "name": "c4"
            }
          ],
          "foo3": "bar3",
          "foo4": "bar4"
        },
        "output": {
          "foo1": "bar1",
          "foo2": "bar2",
          "items": [
            {
              "name": "c1",
              "version": "v1",
              "foo": "bar"
            },
            {
              "name": "c5",
              "version": "NA"
            },
            {
              "name": "c2",
              "version": "v2",
              "fooArr": []
            },
            {
              "name": "c3",
              "version": "v3"
            },
            {
              "name": "c4",
              "version": "NA"
            }
          ],
          "foo3": "bar3",
          "foo4": "bar4"
        }
      }
    ],
    "identifier": 75803544
  },
  {
    "context": [
      "My goal is to modify values for \"stringA\" and \"stringB\" but only for \"people\" with name == \"bob\" and only for \"clients\" with \"instance\" != \"0\".",
      "Traverse to the desired locations using `select` to filter (I added `// empty` to ignore fields producing `null`), then update `|=` to your desired value using `sub` for a regex substitution.",
      "jq --arg name bob --arg prefix newprefix '\n  (.people[] | select(.name == $name).clients[]\n  | select(.instance != \"0\") | (.stringA, .stringB) // empty)\n  |= sub(\"^.*/\"; $prefix + \"/\")\n'\n",
      "The following has the advantage of being portable, e.g. it works with jaq as well as jq:",
      ".people |= map(\n   if .name == $name\n   then .clients |= map(\n      if .instance != \"0\"\n      then if .stringA then .stringA |= sub(\"prefix[^/]*\"; $prefix) else . end\n      | if .stringB then .stringB |= sub(\"prefix[^/]*\"; $prefix) else . end\n      else . end)\n   else . end) "
    ],
    "utterance": "Change the values of 'stringA' and 'stringB' to start with a new prefix for clients of the person named 'bob', but only if the client's 'instance' is not '0'.",
    "expressions": [
      "(.people[] | select(.name == $name).clients[] | select(.instance != \"0\") | (.stringA, .stringB) // empty) |= sub(\"^.*/\"; $prefix + \"/\")",
      ".people |= map(\n   if .name == $name\n   then .clients |= map(\n      if .instance != \"0\"\n      then if .stringA then .stringA |= sub(\"prefix[^/]*\"; $prefix) else . end\n      | if .stringB then .stringB |= sub(\"prefix[^/]*\"; $prefix) else . end\n      else . end)\n   else . end)"
    ],
    "data": [
      {
        "input": {
          "misc": {
            "color": "blue",
            "id": "yyyy-12345",
            "birthdate": "2020-12-25",
            "tools": [
              {
                "type": "power",
                "name": "hammer"
              },
              {
                "type": "manual",
                "name": "grinder"
              }
            ]
          },
          "people": [
            {
              "name": "bob",
              "profession": "analyst",
              "clients": [
                {
                  "name": "alice",
                  "instance": "3",
                  "stringA": "prefix1/suffix-stuff"
                },
                {
                  "name": "richard",
                  "instance": "2",
                  "stringA": "prefix1/suffix-stuff-lkasjdlflsd",
                  "stringB": "prefix2/suffix-stuff-lllaksjllsdkf",
                  "stringC": "prefix2/suffix-stuff-jhfhklasldj"
                },
                {
                  "name": "melanie",
                  "instance": "0",
                  "stringA": "prefix1/suffix-stuff-lkalalajskljlklj",
                  "stringB": "prefix2/suffix-stuff-aljksdljsd"
                }
              ]
            },
            {
              "name": "sarah",
              "profession": "developer",
              "clients": [
                {
                  "name": "george",
                  "instance": "0",
                  "stringA": "prefix1/suffix-stuff-xx-klasjdlk",
                  "stringB": "prefix2/suffix-stuff-yy-lkajsldf",
                  "stringC": "prefix3/suffix-stuff-lkklkl-lkasjdl"
                },
                {
                  "name": "anna",
                  "instance": "4",
                  "stringA": "prefix1/suffix-stuff-aa-lkadslkjjj",
                  "stringB": "prefix3/suffix-stuff-bb-lkasdjfl",
                  "stringC": "prefix2/suffix-stuff-cc-lkasjdf"
                },
                {
                  "name": "michael",
                  "instance": "0",
                  "stringA": "prefix1/suffix-stuff-ttlkajlksdfsd",
                  "stringB": "prefix2/suffix-stuff-rrklajsdlf",
                  "stringC": "prefix3/suffix-stuff-lkljlkjxx"
                }
              ]
            }
          ]
        },
        "output": {
          "misc": {
            "color": "blue",
            "id": "yyyy-12345",
            "birthdate": "2020-12-25",
            "tools": [
              {
                "type": "power",
                "name": "hammer"
              },
              {
                "type": "manual",
                "name": "grinder"
              }
            ]
          },
          "people": [
            {
              "name": "bob",
              "profession": "analyst",
              "clients": [
                {
                  "name": "alice",
                  "instance": "3",
                  "stringA": "newprefix/suffix-stuff"
                },
                {
                  "name": "richard",
                  "instance": "2",
                  "stringA": "newprefix/suffix-stuff-lkasjdlflsd",
                  "stringB": "newprefix/suffix-stuff-lllaksjllsdkf",
                  "stringC": "prefix2/suffix-stuff-jhfhklasldj"
                },
                {
                  "name": "melanie",
                  "instance": "0",
                  "stringA": "prefix1/suffix-stuff-lkalalajskljlklj",
                  "stringB": "prefix2/suffix-stuff-aljksdljsd"
                }
              ]
            },
            {
              "name": "sarah",
              "profession": "developer",
              "clients": [
                {
                  "name": "george",
                  "instance": "0",
                  "stringA": "prefix1/suffix-stuff-xx-klasjdlk",
                  "stringB": "prefix2/suffix-stuff-yy-lkajsldf",
                  "stringC": "prefix3/suffix-stuff-lkklkl-lkasjdl"
                },
                {
                  "name": "anna",
                  "instance": "4",
                  "stringA": "prefix1/suffix-stuff-aa-lkadslkjjj",
                  "stringB": "prefix3/suffix-stuff-bb-lkasdjfl",
                  "stringC": "prefix2/suffix-stuff-cc-lkasjdf"
                },
                {
                  "name": "michael",
                  "instance": "0",
                  "stringA": "prefix1/suffix-stuff-ttlkajlksdfsd",
                  "stringB": "prefix2/suffix-stuff-rrklajsdlf",
                  "stringC": "prefix3/suffix-stuff-lkljlkjxx"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 75770289
  },
  {
    "context": [
      "I need to extract \"rule-number and hits.value\" from the below JSON data but I'm unable to fetch complete data using a single command.",
      "when I use below jq command it only gives me the output of 3rd rule.",
      "Similarly, when I use below command it only extracts 1st 2 data and fails to extract the 3rd one.",
      "2nd command works correctly as per my understanding but now I want to extract all the data using single command.",
      "So, help me to get a single command to extract the required data.",
      "My understanding is that the second `.rulebase` (i.e., `.rulebase.rulebase`) may exist or not; if it exists, it replaces the first `.rulebase` for the source of data (`.rule-number` and `.hits.value`).",
      "the overall solution:\n```\njq '.rulebase[] | .rulebase[]? // . | \"\\(.\"rule-number\"), \\(.hits.value)\"'\n```"
    ],
    "utterance": "Extract all rule-number and hits.value pairs from both top-level and nested rulebase arrays, handling missing fields gracefully.",
    "expressions": [
      ".rulebase[] | .rulebase[]? // . | \"\\(.\"rule-number\"), \\(.hits.value)\""
    ],
    "data": [
      {
        "input": {
          "uid": "38271c2f-ab44-4e25-9aa4-e219cb6e12cf",
          "name": "Network",
          "rulebase": [
            {
              "uid": "39c3ec50-1936-40c1-a775-f6f382027b31",
              "type": "access-rule",
              "domain": {
                "uid": "41e821a0-3720-11e3-aa6e-0800200c9fde",
                "name": "SMC User",
                "domain-type": "domain"
              },
              "rule-number": 1,
              "track": {
                "type": "598ead32-aa42-4615-90ed-f51a5928d41d",
                "per-session": false,
                "per-connection": true,
                "accounting": false,
                "enable-firewall-session": false,
                "alert": "none"
              },
              "source": [
                "97aeb369-9aea-11d5-bd16-0090272ccb30"
              ],
              "source-negate": false,
              "destination": [
                "97aeb369-9aea-11d5-bd16-0090272ccb30"
              ],
              "destination-negate": false,
              "service": [
                "97aeb443-9aea-11d5-bd16-0090272ccb30",
                "18ec9eaa-1657-4240-ab97-5f234623336b"
              ],
              "service-negate": false,
              "service-resource": "",
              "vpn": [
                "97aeb369-9aea-11d5-bd16-0090272ccb30"
              ],
              "action": "6c488338-8eec-4103-ad21-cd461ac2c472",
              "action-settings": {
                "enable-identity-captive-portal": false
              },
              "content": [
                "97aeb369-9aea-11d5-bd16-0090272ccb30"
              ],
              "content-negate": false,
              "content-direction": "any",
              "time": [
                "97aeb369-9aea-11d5-bd16-0090272ccb30"
              ],
              "hits": {
                "percentage": "45%",
                "level": "medium",
                "value": 495,
                "first-date": {
                  "posix": 1676788067000,
                  "iso-8601": "2023-02-19T11:57+0530"
                },
                "last-date": {
                  "posix": 1677899191000,
                  "iso-8601": "2023-03-04T08:36+0530"
                }
              },
              "custom-fields": {
                "field-1": "",
                "field-2": "",
                "field-3": ""
              },
              "meta-info": {
                "lock": "unlocked",
                "validation-state": "ok",
                "last-modify-time": {
                  "posix": 1676788056454,
                  "iso-8601": "2023-02-19T11:57+0530"
                },
                "last-modifier": "admin",
                "creation-time": {
                  "posix": 1676788030368,
                  "iso-8601": "2023-02-19T11:57+0530"
                },
                "creator": "admin"
              },
              "comments": "",
              "enabled": true,
              "install-on": [
                "6c488338-8eec-4103-ad21-cd461ac2c476"
              ],
              "available-actions": {
                "edit": "true",
                "delete": "true",
                "clone": "not_supported"
              }
            },
            {
              "uid": "751ef538-e21b-40ac-a1bf-9562c5bc3eb7",
              "type": "access-rule",
              "domain": {
                "uid": "41e821a0-3720-11e3-aa6e-0800200c9fde",
                "name": "SMC User",
                "domain-type": "domain"
              },
              "rule-number": 2,
              "track": {
                "type": "598ead32-aa42-4615-90ed-f51a5928d41d",
                "per-session": false,
                "per-connection": true,
                "accounting": false,
                "enable-firewall-session": false,
                "alert": "none"
              },
              "source": [
                "97aeb369-9aea-11d5-bd16-0090272ccb30"
              ],
              "source-negate": false,
              "destination": [
                "411dc962-10b5-463d-84a5-3c29aaf74858"
              ],
              "destination-negate": false,
              "service": [
                "97aeb443-9aea-11d5-bd16-0090272ccb30"
              ],
              "service-negate": false,
              "service-resource": "",
              "vpn": [
                "97aeb369-9aea-11d5-bd16-0090272ccb30"
              ],
              "action": "6c488338-8eec-4103-ad21-cd461ac2c472",
              "action-settings": {
                "enable-identity-captive-portal": false
              },
              "content": [
                "97aeb369-9aea-11d5-bd16-0090272ccb30"
              ],
              "content-negate": false,
              "content-direction": "any",
              "time": [
                "97aeb369-9aea-11d5-bd16-0090272ccb30"
              ],
              "hits": {
                "percentage": "0%",
                "level": "zero",
                "value": 0
              },
              "custom-fields": {
                "field-1": "",
                "field-2": "",
                "field-3": ""
              },
              "meta-info": {
                "lock": "unlocked",
                "validation-state": "ok",
                "last-modify-time": {
                  "posix": 1677291569962,
                  "iso-8601": "2023-02-25T07:49+0530"
                },
                "last-modifier": "admin",
                "creation-time": {
                  "posix": 1677291560424,
                  "iso-8601": "2023-02-25T07:49+0530"
                },
                "creator": "admin"
              },
              "comments": "For 1.1.1.2",
              "enabled": true,
              "install-on": [
                "6c488338-8eec-4103-ad21-cd461ac2c476"
              ],
              "available-actions": {
                "edit": "true",
                "delete": "true",
                "clone": "not_supported"
              }
            },
            {
              "uid": "1f4dcd29-dac1-4f65-9aa3-cb0041b68c00",
              "name": "internet rules",
              "type": "access-section",
              "from": 3,
              "to": 3,
              "rulebase": [
                {
                  "uid": "df594bf8-8eee-422c-8a5f-01722fc71417",
                  "type": "access-rule",
                  "domain": {
                    "uid": "41e821a0-3720-11e3-aa6e-0800200c9fde",
                    "name": "SMC User",
                    "domain-type": "domain"
                  },
                  "rule-number": 3,
                  "track": {
                    "type": "598ead32-aa42-4615-90ed-f51a5928d41d",
                    "per-session": false,
                    "per-connection": true,
                    "accounting": false,
                    "enable-firewall-session": false,
                    "alert": "none"
                  },
                  "source": [
                    "97aeb369-9aea-11d5-bd16-0090272ccb30"
                  ],
                  "source-negate": false,
                  "destination": [
                    "14745150-feab-4830-b60b-e0c39cd22758"
                  ],
                  "destination-negate": false,
                  "service": [
                    "97aeb443-9aea-11d5-bd16-0090272ccb30"
                  ],
                  "service-negate": false,
                  "service-resource": "",
                  "vpn": [
                    "97aeb369-9aea-11d5-bd16-0090272ccb30"
                  ],
                  "action": "6c488338-8eec-4103-ad21-cd461ac2c472",
                  "action-settings": {
                    "enable-identity-captive-portal": false
                  },
                  "content": [
                    "97aeb369-9aea-11d5-bd16-0090272ccb30"
                  ],
                  "content-negate": false,
                  "content-direction": "any",
                  "time": [
                    "97aeb369-9aea-11d5-bd16-0090272ccb30"
                  ],
                  "hits": {
                    "percentage": "0%",
                    "level": "zero",
                    "value": 0
                  },
                  "custom-fields": {
                    "field-1": "",
                    "field-2": "",
                    "field-3": ""
                  },
                  "meta-info": {
                    "lock": "unlocked",
                    "validation-state": "ok",
                    "last-modify-time": {
                      "posix": 1677291841727,
                      "iso-8601": "2023-02-25T07:54+0530"
                    },
                    "last-modifier": "admin",
                    "creation-time": {
                      "posix": 1677291513151,
                      "iso-8601": "2023-02-25T07:48+0530"
                    },
                    "creator": "admin"
                  },
                  "comments": "For 1.1.1.1",
                  "enabled": false,
                  "install-on": [
                    "6c488338-8eec-4103-ad21-cd461ac2c476"
                  ],
                  "available-actions": {
                    "edit": "true",
                    "delete": "true",
                    "clone": "not_supported"
                  }
                }
              ]
            },
            {
              "uid": "3e6e74ef-5cdd-48b1-adc1-897bfa10974d",
              "name": "Cleanup Rule",
              "type": "access-section",
              "from": 4,
              "to": 4,
              "rulebase": [
                {
                  "uid": "2b922948-da96-4c9d-a654-063e0183f9ae",
                  "name": "Cleanup rule",
                  "type": "access-rule",
                  "domain": {
                    "uid": "41e821a0-3720-11e3-aa6e-0800200c9fde",
                    "name": "SMC User",
                    "domain-type": "domain"
                  },
                  "rule-number": 4,
                  "track": {
                    "type": "598ead32-aa42-4615-90ed-f51a5928d41d",
                    "per-session": false,
                    "per-connection": true,
                    "accounting": false,
                    "enable-firewall-session": false,
                    "alert": "none"
                  },
                  "source": [
                    "97aeb369-9aea-11d5-bd16-0090272ccb30"
                  ],
                  "source-negate": false,
                  "destination": [
                    "97aeb369-9aea-11d5-bd16-0090272ccb30"
                  ],
                  "destination-negate": false,
                  "service": [
                    "97aeb369-9aea-11d5-bd16-0090272ccb30"
                  ],
                  "service-negate": false,
                  "service-resource": "",
                  "vpn": [
                    "97aeb369-9aea-11d5-bd16-0090272ccb30"
                  ],
                  "action": "6c488338-8eec-4103-ad21-cd461ac2c473",
                  "action-settings": {},
                  "content": [
                    "97aeb369-9aea-11d5-bd16-0090272ccb30"
                  ],
                  "content-negate": false,
                  "content-direction": "any",
                  "time": [
                    "97aeb369-9aea-11d5-bd16-0090272ccb30"
                  ],
                  "hits": {
                    "percentage": "55%",
                    "level": "medium",
                    "value": 596,
                    "first-date": {
                      "posix": 1676786609000,
                      "iso-8601": "2023-02-19T11:33+0530"
                    },
                    "last-date": {
                      "posix": 1677899181000,
                      "iso-8601": "2023-03-04T08:36+0530"
                    }
                  },
                  "custom-fields": {
                    "field-1": "",
                    "field-2": "",
                    "field-3": ""
                  },
                  "meta-info": {
                    "lock": "unlocked",
                    "validation-state": "ok",
                    "last-modify-time": {
                      "posix": 1676788047995,
                      "iso-8601": "2023-02-19T11:57+0530"
                    },
                    "last-modifier": "admin",
                    "creation-time": {
                      "posix": 1668629634218,
                      "iso-8601": "2022-11-17T01:43+0530"
                    },
                    "creator": "System"
                  },
                  "comments": "",
                  "enabled": true,
                  "install-on": [
                    "6c488338-8eec-4103-ad21-cd461ac2c476"
                  ],
                  "available-actions": {
                    "edit": "true",
                    "delete": "true",
                    "clone": "not_supported"
                  }
                }
              ]
            }
          ],
          "objects-dictionary": [],
          "from": 1,
          "to": 4,
          "total": 4
        },
        "output": [
          "1, 495",
          "2, 0",
          "3, 0",
          "4, 596"
        ]
      }
    ],
    "identifier": 75633690
  }
]