[
  {
    "context": [
      "Given the following input:\r\n{\r\n  \"text\": \"a1\\nb2\"\r\n}\r\nHow do I get the following output:\r\n[\r\n  {\r\n    \"letter\": \"a\",\r\n    \"number\": 1\r\n  },\r\n  {\r\n    \"letter\": \"b\",\r\n    \"number\": 2\r\n  }\r\n]",
      "Why not just wrap the `capture` in a new array:\r\n.text | [ capture(\"(?<letter>[a-z])(?<number>[0-9])\";\"g\") ]"
    ],
    "utterance": "Extract all matches of a letter followed by a digit from the string under the key 'text' and return an array of objects with 'letter' and 'number' fields.",
    "expressions": [
      ".text | [ capture(\"(?<letter>[a-z])(?<number>[0-9])\";\"g\") ]"
    ],
    "data": [
      {
        "input": {
          "text": "a1\nb2"
        },
        "output": [
          {
            "letter": "a",
            "number": "1"
          },
          {
            "letter": "b",
            "number": "2"
          }
        ]
      }
    ],
    "identifier": 73892767
  },
  {
    "context": [
      "now I am trying to save these value in file with a variable assigned to it.",
      "need output in file as \r\n\r\n    a=10\r\n    b=20\r\n    c=30\r\n    d=40",
      "You could use `implode` to create the letters by array index, which is provided in `.key` when `to_entries` is applied to an array.",
      "jq -r 'to_entries[] | \"\\([.key + 97] | implode)=\\(.value)\"'",
      "To provide individual names, you can introduce an array of names and use `transpose` to make the alignment:",
      "jq -r '\n  [[\"Price\", \"Amount\", \"Value\", \"Tax\"], .]\n  | transpose[] | \"\\(first)=\\(last)\"'"
    ],
    "utterance": "Assign the values 10, 20, 30, and 40 to variables named a, b, c, and d respectively in export-style lines.",
    "expressions": [
      "to_entries[] | \"\\([.key + 97] | implode)=\\(.value)\""
    ],
    "data": [
      {
        "input": [
          10,
          20,
          30,
          40
        ],
        "output": [
          "a=10",
          "b=20",
          "c=30",
          "d=40"
        ]
      }
    ],
    "identifier": 73886731
  },
  {
    "context": [
      "I want to get spicific keys like",
      ".rows[].title",
      ".rows[].panels[].title",
      ".rows[].panels[].description",
      ".rows[].panels[].format",
      ".rows[].panels[].targets[].expr",
      "and transform it to new JSON with following structure:",
      "{\n    \"row_title\": \".rows[].title\",\n    \"panels\": [ ... ]\n}",
      "Tried to do it with map(), but cannot understand how make nested arrays.",
      "Transforming the input array with all nested arrays and keeping only certain properties of each object? Any property not listed in the jq program will be ignored and dropped from the output.",
      "map({\n    row_title,\n    panels: .panels | map({\n        panel_title,\n        panel_description,\n        panel_format,\n        panel_exprs: .panel_exprs | map({\n            expr\n        })\n    })\n})"
    ],
    "utterance": "Extract the fields title from rows, title, description, and format from each panel within rows, and expr from each target within panels, and produce an array where each row contains these fields as nested arrays.",
    "expressions": [
      "map({\n    row_title: .title,\n    panels: .panels | map({\n        panel_title: .title,\n        panel_description: .description,\n        panel_format: .format,\n        panel_exprs: .targets | map({ expr })\n    })\n})"
    ],
    "identifier": 73892015
  },
  {
    "context": [
      "I have two arrays with the same amount of elements but with different keys/values. I want to integrate the key/value of the second array into the first for each index/position.",
      "The result I would like to achieve:",
      "[    ",
      "  {",
      "    \"name\": \"xxx\",",
      "    \"url\": \"yyy\",",
      "    \"thumbnail\": \"nnn\",",
      "    \"spotifyUrl\": \"first-spotify-url\"",
      "  },",
      "  {",
      "    \"name\": \"bla bla\",",
      "    \"url\": \"some-url\",",
      "    \"thumbnail\": \"another-pic\",",
      "    \"spotifyUrl\": \"second-spotify-url\"",
      "  }",
      "]",
      "It\u2019s easier than that.",
      "jq -s 'transpose | map(add)' 1.json 2.json"
    ],
    "utterance": "Merge two equal-length arrays by combining corresponding objects at each index, so that each resulting object contains keys and values from both source objects.",
    "expressions": [
      "jq -s 'transpose | map(add)' 1.json 2.json"
    ],
    "data": [
      {
        "input": [
          [
            {
              "name": "xxx",
              "url": "yyy",
              "thumbnail": "nnn"
            },
            {
              "name": "bla bla",
              "url": "some-url",
              "thumbnail": "another-pic"
            }
          ],
          [
            {
              "spotifyUrl": "first-spotify-url"
            },
            {
              "spotifyUrl": "second-spotify-url"
            }
          ]
        ],
        "output": [
          {
            "name": "xxx",
            "url": "yyy",
            "thumbnail": "nnn",
            "spotifyUrl": "first-spotify-url"
          },
          {
            "name": "bla bla",
            "url": "some-url",
            "thumbnail": "another-pic",
            "spotifyUrl": "second-spotify-url"
          }
        ]
      }
    ],
    "identifier": 73881065
  },
  {
    "context": [
      "I'm trying to use `jq` tool on `bash` in the shortest and tidiest form, to check if a product has a barcode and it's categorized as food. In other words, check if an object with `type=barcode` exists in the array, then check if there is an object with `type=category` together with `name=food`.",
      "This outputs `true` or `false` based on your requirements:\n\n```\nany(.type==\"barcode\") and any(.type==\"category\" and .name==\"food\")\n```",
      "group_by(.type)\n| map({\n    key: first.type,\n    value: map(.name)\n})\n| from_entries\n| .category as $cat\n| .barcode and (\"food\"|IN($cat[]))"
    ],
    "utterance": "Check if the array contains an object with type equal to barcode and another object with type equal to category and name equal to food.",
    "expressions": [
      "any(.type==\"barcode\") and any(.type==\"category\" and .name==\"food\")",
      "group_by(.type)\n| map({\n    key: first.type,\n    value: map(.name)\n})\n| from_entries\n| .category as $cat\n| .barcode and (\"food\"|IN($cat[]))"
    ],
    "data": [
      {
        "input": [
          {
            "type": "category",
            "name": "food"
          },
          {
            "type": "category",
            "name": "fruit"
          },
          {
            "type": "barcode",
            "name": "123456"
          }
        ],
        "output": true
      }
    ],
    "identifier": 73893049
  },
  {
    "context": [
      "Now, how to make the following result and save it.",
      "{\r\n  \"Test1\": {\r\n    \"one\": \"Apple\",\r\n    \"two\": \"Banana\"\r\n  },\r\n  \"Test2\": {\r\n    \"one\": \"Kiwi\",\r\n    \"two\": \"Tomato\"\r\n  }  \r\n}",
      "jq -n \\\r\n   --argjson Test1 \"$(jq -n --arg one 'Apple' --arg two 'Banana' '$ARGS.named')\" \\\r\n   --argjson Test2 \"$(jq -n --arg one 'Kiwi'  --arg two 'Tomato' '$ARGS.named')\" \\\r\n  '$ARGS.named' > output.json",
      "jq -cn  --arg one 'Apple' --arg two 'Banana' '{Test1: $ARGS.named}'",
      "jq -cn  --arg one 'Kiwi'  --arg two 'Tomato' '{Test2: $ARGS.named}'",
      "jq -s add > output.json"
    ],
    "utterance": "Create a file containing an object with keys Test1 and Test2, each mapping to an object with keys one and two with values Apple, Banana, Kiwi, and Tomato respectively.",
    "expressions": [
      "jq -n --argjson Test1 \"$(jq -n --arg one 'Apple' --arg two 'Banana' '$ARGS.named')\" --argjson Test2 \"$(jq -n --arg one 'Kiwi' --arg two 'Tomato' '$ARGS.named')\" '$ARGS.named'",
      "{ jq -cn --arg one 'Apple' --arg two 'Banana' '{Test1: $ARGS.named}'; jq -cn --arg one 'Kiwi' --arg two 'Tomato' '{Test2: $ARGS.named}'; } | jq -s add"
    ],
    "data": [
      {
        "input": null,
        "output": {
          "Test1": {
            "one": "Apple",
            "two": "Banana"
          },
          "Test2": {
            "one": "Kiwi",
            "two": "Tomato"
          }
        }
      }
    ],
    "identifier": 73885999
  },
  {
    "context": [
      "echo '[1,2,3,4,3,2,1]' | jq '.[[1]]' # output: [0,6]; 1 occurs at index 0 and 6",
      "echo '[1,2,3,4,3,2,1]' | jq '.[[2,3]]' # output: [1]; [2,3] occurs at index 1",
      "jq -nc '[0,1,2,3,4,1,2] | .[[1,2]]'",
      "[1,5]",
      "> The input may be an array, in which case if s is an array then the indices output will be those where all elements in . match those of s."
    ],
    "utterance": "Return all starting indices where the exact subarray [2,3] occurs within the top-level array.",
    "expressions": [
      ".[[2,3]]"
    ],
    "data": [
      {
        "input": [
          1,
          2,
          3,
          4,
          3,
          2,
          1
        ],
        "output": [
          1
        ]
      },
      {
        "input": [
          0,
          1,
          2,
          3,
          4,
          1,
          2
        ],
        "output": [
          1,
          5
        ]
      }
    ],
    "identifier": 73895618
  },
  {
    "context": [
      "What I want:\r\n\r\n```none\r\ncontainer=container1,namespace=namespace1,pod=pod1\r\n1 1664418600\r\n2 1664418900\r\n6 1664419200\r\n8 1664419500\r\n7 1664419800\r\n9 1664420100\r\ncontainer=container2,namespace=container2,pod=pod2\r\n1 1664420100\r\n```",
      "Putting the two programs together:\r\n\r\n```\r\n(.metric | to_entries | map(join(\"=\")) | join(\",\")),\r\n(.values[] | [last,first] | join(\" \"))\r\n```\r\n\r\nAnd then execute with raw output enabled",
      "An alternative for 2.2. and 2.3. could be `\"\\(last) \\(first)\"`, i.e. `values[] | \"\\(last) \\(first)\"`. Or `[last,first]` could be replaced with `reverse`: `.values[] | reverse | join(\" \")`."
    ],
    "utterance": "For each top-level object, print a header line listing container, namespace, and pod as key=value pairs joined by commas, then print each inner [timestamp, value] pair as 'value timestamp' lines.",
    "expressions": [
      "(.metric | to_entries | map(join(\"=\")) | join(\",\")), (.values[] | [last,first] | join(\" \"))",
      "(.metric | to_entries | map(join(\"=\")) | join(\",\")), (.values[] | \"\\(last) \\(first)\")",
      "(.metric | to_entries | map(join(\"=\")) | join(\",\")), (.values[] | reverse | join(\" \"))"
    ],
    "data": [
      {
        "input": [
          {
            "metric": {
              "container": "container1",
              "namespace": "namespace1",
              "pod": "pod1"
            },
            "values": [
              [
                1664418600,
                "1"
              ],
              [
                1664418900,
                "2"
              ],
              [
                1664419200,
                "6"
              ],
              [
                1664419500,
                "8"
              ],
              [
                1664419800,
                "7"
              ],
              [
                1664420100,
                "9"
              ]
            ]
          },
          {
            "metric": {
              "container": "container2",
              "namespace": "namespace2",
              "pod": "pod2"
            },
            "values": [
              [
                1664420100,
                "1"
              ]
            ]
          }
        ],
        "output": "container=container1,namespace=namespace1,pod=pod1\n1 1664418600\n2 1664418900\n6 1664419200\n8 1664419500\n7 1664419800\n9 1664420100\ncontainer=container2,namespace=namespace2,pod=pod2\n1 1664420100\n"
      }
    ],
    "identifier": 73890739
  },
  {
    "context": [
      "BTW: https://stackoverflow.com/questions/67391180/use-newline-with-jq suggests to use `printf %b` to obtain `\\n` instead of `\\\\n`, which works for bash,. but discrepancy in `zsh` between the modes is still there.",
      "You can avoid this by switching from `echo` to `printf`.",
      "% OUT=$(jq --null-input --compact-output --raw-output --monochrome-output --arg test \"$(printf %b 'A\\nB')\" '{test: $test}')",
      "% printf '%s\\n' \"$OUT\"",
      "{ \"test\": \"A\\nB\" }"
    ],
    "utterance": "Format a string argument that includes an actual newline character as a value in an object with the key 'test' and output the result compactly.",
    "expressions": [
      "jq --null-input --compact-output --raw-output --monochrome-output --arg test \"$(printf %b 'A\\nB')\" '{test: $test}'"
    ],
    "identifier": 73899110
  },
  {
    "context": [
      "Given the following (sample) input, how can I create a new object which groups together each person by their country?",
      "I know about `group_by`, but it returns an array of arrays.",
      "Instead, I'd prefer to transform the document into the following structure:",
      "{\n  \"germany\": [ ... ],\n  \"usa\": [ ... ]\n}",
      "def group(k):\n  group_by(k) | map({ key: first|k, value: . }) | from_entries;",
      "group(.country)",
      "reduce .[] as $m ({}; .[$m.country] += [$m])",
      "def grp(f): reduce .[] as $m ({}; .[$m|f] += [$m]);\n\ngrp(.country)",
      "group_by(.country) | map({ (.[0].country): . }) | add"
    ],
    "utterance": "Group items by country so that each country is a key and its value is the array of people from that country.",
    "expressions": [
      "def group(k): group_by(k) | map({ key: first|k, value: . }) | from_entries; group(.country)",
      "reduce .[] as $m ({}; .[$m.country] += [$m])",
      "def grp(f): reduce .[] as $m ({}; .[$m|f] += [$m]); grp(.country)",
      "group_by(.country) | map({ (.[0].country): . }) | add"
    ],
    "data": [
      {
        "input": [
          {
            "name": "anna",
            "country": "germany"
          },
          {
            "name": "lisa",
            "country": "germany"
          },
          {
            "name": "john",
            "country": "usa"
          }
        ],
        "output": {
          "germany": [
            {
              "name": "anna",
              "country": "germany"
            },
            {
              "name": "lisa",
              "country": "germany"
            }
          ],
          "usa": [
            {
              "name": "john",
              "country": "usa"
            }
          ]
        }
      }
    ],
    "identifier": 73893818
  },
  {
    "context": [
      "I am trying to gather multiple json fields from a curl call in the command line. I have only been able to get one field at a time, each time it requires me to redo the curl call.",
      "How can I gather both fields in just one curl call?",
      "Just separate them with commas:",
      "url \"https://www.somewebsite.com\" | jq -r '.parent | .field_1, .field_2'"
    ],
    "utterance": "Extract both field_1 and field_2 located under parent in a single query.",
    "expressions": [
      ".parent | .field_1, .field_2"
    ],
    "identifier": 73915736
  },
  {
    "context": [
      "I have a bash array. For each element in the bash array, I want to update a JSON array.",
      "The JSON looks like the below. I am wanting to update the *fruit* array.",
      "```\r\n  \"foods\": {\r\n    \"perishable\": {\r\n      \"fruit\": []",
      "fruit_array=(\"banana\" \"orange\")",
      "It should look something like this:",
      "  \"foods\": {\r\n    \"perishable\": {\r\n      \"fruit\": [\r\n        { \r\n          \"001\": {\r\n            \"002\": \"banana\"\r\n          }\r\n        },\r\n        { \r\n          \"001\": {\r\n            \"002\": \"orange\"\r\n          }\r\n        }",
      "JQ can do all that on its own; you don't need a loop or anything.",
      "jq '.foods.perishable.fruit += (\r\n  $ARGS.positional\r\n  | map({\"001\": {\"002\": .}})\r\n)' template.json --args \"${fruit_array[@]}\" >template_with_fruit.json",
      "If you pass your array as a space delimited string, you can use JQ like so:",
      "jq --arg fruits \"$fruit_array\" \\\r\n    '.foods.perishable.fruit |= ($fruits | split(\" \") | map({ \"001\": { \"002\": . } }))' input",
      "{\r\n  \"foods\": {\r\n    \"perishable\": {\r\n      \"fruit\": [\r\n        {\r\n          \"001\": {\r\n            \"002\": \"banana\"\r\n          }\r\n        },\r\n        {\r\n          \"001\": {\r\n            \"002\": \"orange\"\r\n          }\r\n        }\r\n      ]\r\n    }\r\n  }\r\n}"
    ],
    "utterance": "Add an array of string values (e.g., banana, orange) to the fruit array so that each element has the structure {\"001\": {\"002\": value}}.",
    "expressions": [
      ".foods.perishable.fruit += ( $ARGS.positional | map({\"001\": {\"002\": .}}) )",
      ".foods.perishable.fruit |= ($fruits | split(\" \") | map({ \"001\": { \"002\": . } }))"
    ],
    "data": [
      {
        "input": {
          "foods": {
            "perishable": {
              "fruit": []
            }
          }
        },
        "output": {
          "foods": {
            "perishable": {
              "fruit": [
                {
                  "001": {
                    "002": "banana"
                  }
                },
                {
                  "001": {
                    "002": "orange"
                  }
                }
              ]
            }
          }
        }
      }
    ],
    "identifier": 73906627
  },
  {
    "context": [
      "I want to produce tsv format like following :",
      "Application  User   Access\ngrafana      admin  admin\n             user1  read\n             user2  edit",
      "is there a way to only display application name in first row ?",
      "One could utilize the facts that `transpose` compensates for a rigged matrix using `null` values, and that `@tsv` gracefully translates `null` values to empty strings:",
      "[[\"Application\"], [\"User\"], [\"Access\"]],\n[[[.application]], [.users[] | [.\"display-name\", .access]]]\n| transpose[] | flatten(1) | @tsv",
      "[\"Application\", \"User\", \"Access\"], (\n  [[[.application]], [.users[]|[.\"display-name\",.access]]]\n  | transpose[] | flatten(1)\n) | @tsv"
    ],
    "utterance": "Produce a tab-separated table with columns Application, User, and Access, where the first row contains the application name and subsequent rows leave the application cell empty, listing each user and access level.",
    "expressions": [
      "[[\"Application\"], [\"User\"], [\"Access\"]],\n[[[.application]], [.users[] | [.\"display-name\", .access]]]\n| transpose[] | flatten(1) | @tsv",
      "[\"Application\", \"User\", \"Access\"], (\n  [[[.application]], [.users[]|[.\"display-name\",.access]]]\n  | transpose[] | flatten(1)\n) | @tsv"
    ],
    "data": [
      {
        "input": {
          "application": "grafana",
          "users": {
            "admin": {
              "display-name": "admin",
              "access": "admin"
            },
            "user1": {
              "display-name": "user1",
              "access": "read"
            },
            "user2": {
              "display-name": "user2",
              "access": "edit"
            }
          }
        },
        "output": "Application\tUser\tAccess\ngrafana\tadmin\tadmin\n\tuser1\tread\n\tuser2\tedit\n"
      }
    ],
    "identifier": 73913849
  },
  {
    "context": [
      "I know to get a unique from one key - `unique_by('.[].name)`",
      "I want to get output by checking for unique values in two keys",
      "but how to do for two keys like `unique_by('.[].name,.[].url')`  and return the input along with other keys?",
      "Just provide to `unique_by` an array with everything included, so that the array must become unique:",
      "jq 'unique_by([.name, .url])'",
      "Collect the criteria into an array:",
      "unique_by([.name, .url]) "
    ],
    "utterance": "Return elements with unique combinations of 'name' and 'url', preserving all other fields.",
    "expressions": [
      "unique_by([.name, .url])"
    ],
    "data": [
      {
        "input": [
          {
            "name": "abc",
            "url": "https://aa.com",
            "created_at": "2022-09-30T11:17:33.181Z"
          },
          {
            "name": "bb",
            "url": "https://ddd.com",
            "created_at": "2022-09-30T11:14:33.180Z"
          },
          {
            "name": "abc",
            "url": "https://aa.com",
            "created_at": "2022-09-30T11:14:33.180Z"
          }
        ],
        "output": [
          {
            "name": "abc",
            "url": "https://aa.com",
            "created_at": "2022-09-30T11:17:33.181Z"
          },
          {
            "name": "bb",
            "url": "https://ddd.com",
            "created_at": "2022-09-30T11:14:33.180Z"
          }
        ]
      }
    ],
    "identifier": 73917096
  },
  {
    "context": [
      "What I would like is to be able to count the total number of elements within each direct child of `\"main\"`. For example, in the above, `\"main\"` has an array containing 3 direct childs, `\"0\"`, `\"1\"`, `\"2\"`. For `\"0\"`, we have 4 such elements, `\"1\"` we have 3 such elements, and `\"2\"` we have 5 such elements.",
      "Is there a way to use `jq` to return `12` as the final answer for the above?",
      "This produces 12 for your sample input:\n[.main[][] | length] | add",
      ".main|map(map(length)|add)|add",
      ".main|map(map(length))|add|add",
      "[.main[][][]]|length",
      "def count(s): reduce s as $_ (0; .+1);",
      "count(.main[][][])"
    ],
    "utterance": "Count all elements nested under each direct child within the top-level 'main' array, summing the totals.",
    "expressions": [
      "[.main[][] | length] | add",
      ".main|map(map(length)|add)|add",
      ".main|map(map(length))|add|add",
      "[.main[][][]]|length",
      "reduce (.main[][][]) as $_ (0; .+1)",
      "def count(s): reduce s as $_ (0; .+1); count(.main[][][])"
    ],
    "data": [
      {
        "input": {
          "main": [
            {
              "0": [
                {
                  "0": "..."
                },
                {
                  "1": "..."
                },
                {
                  "2": "..."
                },
                {
                  "3": "..."
                }
              ]
            },
            {
              "1": [
                {
                  "0": "..."
                },
                {
                  "1": "..."
                },
                {
                  "2": "..."
                }
              ]
            },
            {
              "2": [
                {
                  "0": "..."
                },
                {
                  "1": "..."
                },
                {
                  "2": "..."
                },
                {
                  "3": "..."
                },
                {
                  "4": "..."
                }
              ]
            }
          ]
        },
        "output": 12
      }
    ],
    "identifier": 73915896
  },
  {
    "context": [
      "Is there a better way to escape string for json usage? I already tried out `jq -Rsa .`, but didn\u2019t work either.",
      "Here\u2019s how to build that JSON with jq:",
      "json=\"$(jq -n --arg body \"$body\" '{ $body }')\"",
      "# or: json=$(printf '%s\\n' \"$body\" | jq -R '{ body: . }')"
    ],
    "utterance": "Create an object with a 'body' key whose value is taken from a shell variable, properly escaping the string for use as HTTP request data.",
    "expressions": [
      "jq -n --arg body \"$body\" '{body: $body}'",
      "printf '%s\\n' \"$body\" | jq -R '{ body: . }'"
    ],
    "data": [
      {
        "input": "A shell variable body containing a message string.",
        "output": {
          "body": "Your message string here"
        }
      }
    ],
    "identifier": 73942028
  },
  {
    "context": [
      "Output #1 is the version info for objects of type A with the `id` value as a key with the value of `version`. `A` objects can be at the top level or at some arbitrary depth in the `referencing` arrays.",
      "The 2nd output is similar: the version info for objects of type B. The can be a chain of type `B` objects referencing other type `B` objects.",
      "You can use `recurse` to traverse the document, `INDEX` to create an object with IDs as keys, `map_values` to format their values using `select` to reduce according to your criteria.",
      "jq --arg type A '\n  .references |= (\n    INDEX(.[] | recurse(.referencing[]?); .id)\n    | map_values(select(.objType == $type) | {version})\n  )\n'",
      "{\n    dependencies: [.. | select(.objType==\"A\")? | { key: .id, value: {version} }] | from_entries\n},\n{\n    dependencies: [.. | select(.objType==\"B\")? | { key: .id, value: {version} }] | from_entries\n}",
      "{\n    dependencies: [.. | select(.objType==\"A\")? | { (.id): {version} }] | add\n}"
    ],
    "utterance": "Extract all objects of type A at any depth and produce an object mapping their ids to their version.",
    "expressions": [
      ".references |= (INDEX(.[] | recurse(.referencing[]?); .id) | map_values(select(.objType == \"A\") | {version}))",
      "{dependencies: [.. | select(.objType==\"A\")? | { key: .id, value: {version} }] | from_entries}",
      "{dependencies: [.. | select(.objType==\"A\")? | { (.id): {version} }] | add}"
    ],
    "data": [
      {
        "input": {
          "references": [
            {
              "version": 5,
              "id": "id1",
              "objType": "A"
            },
            {
              "version": 4,
              "id": "id2",
              "objType": "B",
              "referencing": []
            },
            {
              "version": 4,
              "id": "id3",
              "objType": "B",
              "referencing": [
                {
                  "version": 2,
                  "id": "id4",
                  "objType": "A"
                },
                {
                  "version": 3,
                  "id": "id5",
                  "objType": "B",
                  "referencing": []
                }
              ]
            }
          ]
        },
        "output": {
          "references": {
            "id1": {
              "version": 5
            },
            "id4": {
              "version": 2
            }
          }
        }
      }
    ],
    "identifier": 73916663
  },
  {
    "context": [
      "#jq '.[]|select(.meta.antivirus.enabled==\"true\")' filename.json works,issue with variable substitution in python",
      "match = pyjq.all('.[]|select([\"$query\"]==$value)', records, vars={\"value\": value,\"query\": query})",
      "It works if I hardcode \"query\" - match = pyjq.all('.[]|select(.meta.antivirus.enabled==$value)', records, vars={\"value\": value,\"query\": query})",
      "Variables are intended to be used for _values_, not for jq expressions (at least not directly).",
      "I think the easiest option here is to go for an fstring:",
      "match = pyjq.all(f'.[]|select({query}==$value)', records, vars={\"value\": value})",
      "and it probably makes sense to prepend the period inside the fstring:",
      "match = pyjq.all(f'.[]|select(.{key}==$value)', records, vars={\"value\": value})"
    ],
    "utterance": "Select all elements where the property meta.antivirus.enabled equals the string \"true\".",
    "expressions": [
      ".[] | select(.meta.antivirus.enabled == \"true\")"
    ],
    "data": [
      {
        "input": [
          {
            "name": "alpharetta",
            "meta": {
              "antivirus": {
                "enabled": "true"
              },
              "limits": {
                "cpu": {
                  "enabled": "true",
                  "value": "250m"
                }
              }
            }
          },
          {
            "meta": {
              "allergens": {
                "eggs": "true",
                "nuts": "false",
                "seafood": "false"
              },
              "calories": 230,
              "carbohydrates": {
                "dietary-fiber": "4g",
                "sugars": "1g"
              },
              "fats": {
                "saturated-fat": "0g",
                "trans-fat": "1g"
              }
            },
            "name": "sandwich-nutrition"
          },
          {
            "meta": {
              "allergens": {
                "eggs": "true",
                "nuts": "false",
                "seafood": "true"
              },
              "calories": 440,
              "carbohydrates": {
                "dietary-fiber": "4g",
                "sugars": "2g"
              },
              "fats": {
                "saturated-fat": "0g",
                "trans-fat": "1g"
              }
            },
            "name": "random-nutrition"
          }
        ],
        "output": {
          "name": "alpharetta",
          "meta": {
            "antivirus": {
              "enabled": "true"
            },
            "limits": {
              "cpu": {
                "enabled": "true",
                "value": "250m"
              }
            }
          }
        }
      }
    ],
    "identifier": 73931572
  },
  {
    "context": [
      "When using jq in streaming mode (because 100 GB file) it eats the first element. How can I avoid that?",
      "Use the `--null-input` (or `-n`) flag. That way the standard input is set to `null`, and `inputs` can fetch all actual inputs.",
      "jq -cn --stream \"fromstream(1|truncate_stream(inputs))\""
    ],
    "utterance": "Prevent loss of the first array element when reconstructing data from stream by using null input mode and fetching all streamed input elements.",
    "expressions": [
      "jq -cn --stream 'fromstream(1|truncate_stream(inputs))'"
    ],
    "data": [
      {
        "input": [
          {
            "id": 482,
            "a": "2",
            "b": 1
          },
          {
            "id": 483,
            "a": "3",
            "b": 2
          }
        ],
        "output": [
          {
            "id": 482,
            "a": "2",
            "b": 1
          },
          {
            "id": 483,
            "a": "3",
            "b": 2
          }
        ]
      }
    ],
    "identifier": 73944354
  },
  {
    "context": [
      "my question is can I just display the \"name\" or \"hash\" fields?",
      "curl -i http://localhost:8080/api/v2/torrents/info?category=test | jq --raw-output '.[] | .name'",
      "Remove the `-i` and optionally replace it with `-s` to remove the stats:\n```\ncurl -s http://localhost:8080/api/v2/torrents/info?category=test | jq --raw-output '.[] | .name'\n```"
    ],
    "utterance": "Display only the name field for each object in the array returned by the API endpoint.",
    "expressions": [
      ".[] | .name"
    ],
    "data": [
      {
        "input": [
          {
            "eta": 8640000,
            "f_l_piece_prio": false,
            "force_start": false,
            "hash": "8419d48d86a14335c83fdf4930843438a2f75a6b",
            "last_activity": 1664863523,
            "magnet_uri": "",
            "max_seeding_time": 0,
            "name": "TestTorrentName",
            "num_complete": 12,
            "num_incomplete": 1,
            "num_leechs": 0,
            "num_seeds": 0,
            "priority": 0,
            "progress": 1,
            "ratio": 0,
            "ratio_limit": -2,
            "save_path": "F:\\Completed\\test\\",
            "seeding_time": 0,
            "seeding_time_limit": -2,
            "seen_complete": 1664863523,
            "seq_dl": false,
            "size": 217388295,
            "state": "pausedUP",
            "super_seeding": false,
            "tags": "",
            "time_active": 569,
            "total_size": 217388295,
            "tracker": "udp://open.stealth.si:80/announce",
            "trackers_count": 10,
            "up_limit": -1,
            "uploaded": 0,
            "uploaded_session": 0,
            "upspeed": 0
          }
        ],
        "output": [
          "TestTorrentName"
        ]
      }
    ],
    "identifier": 73946917
  },
  {
    "context": [
      "I need an empty key({}) if all the values are null or remove nulls from the JSON array.",
      "In the below example, I want to filter the nulls from Workloads JSON array.",
      "if all(. == null) then [ {} ] else map(values)",
      "Otherwise, use [map(values)] to only keep values that are not `null`",
      "This recursively (`..`) reduces `arrays` containing (also) `values` (anything but `null`) to only contain those `values`, otherwise (containing nothing but `null`) it replaces them with `[{}]`:",
      "jq '(.. | arrays) |= if any(values) then map(values) else [{}] end'"
    ],
    "utterance": "For all 'Workloads' arrays, replace with [{}] if all elements are null, otherwise remove all null elements.",
    "expressions": [
      ".\"EC2 Instance Metadata\"[].Workloads |= if all(. == null) then [ {} ] else map(values) end",
      "(.. | arrays) |= if any(values) then map(values) else [{}] end"
    ],
    "data": [
      {
        "input": {
          "EC2 Instance Metadata": [
            {
              "EC2 Private IPv4 DNS Name": "compute.internal-1",
              "EC2 Private IPv4 address": "1.2.3.4",
              "Workloads": [
                null
              ],
              "Application Pods": [
                "pod-1"
              ],
              "Application Containers": [
                "container"
              ],
              "Container Images": [
                "image/1.0"
              ]
            },
            {
              "EC2 Private IPv4 DNS Name": "compute.internal-2",
              "EC2 Private IPv4 address": "1.2.3.44",
              "Workloads": [
                null
              ],
              "Application Pods": [
                "pod-2"
              ],
              "Application Containers": [
                "container-2"
              ],
              "Container Images": [
                "image/2.0"
              ]
            },
            {
              "EC2 Private IPv4 DNS Name": "compute.internal-3",
              "EC2 Private IPv4 address": "1.23.3.44",
              "Workloads": [
                "workload-1",
                "workload-2",
                "workload-3",
                null,
                null,
                null,
                "workload-4"
              ],
              "Application Pods": [
                "pod-1",
                "pod-2"
              ],
              "Application Containers": [
                "cnt-1",
                "cnt-2"
              ],
              "Container Images": [
                "image-1",
                "image-2"
              ]
            }
          ]
        },
        "output": {
          "EC2 Instance Metadata": [
            {
              "EC2 Private IPv4 DNS Name": "compute.internal-1",
              "EC2 Private IPv4 address": "1.2.3.4",
              "Workloads": [
                {}
              ],
              "Application Pods": [
                "pod-1"
              ],
              "Application Containers": [
                "container"
              ],
              "Container Images": [
                "image/1.0"
              ]
            },
            {
              "EC2 Private IPv4 DNS Name": "compute.internal-2",
              "EC2 Private IPv4 address": "1.2.3.44",
              "Workloads": [
                {}
              ],
              "Application Pods": [
                "pod-2"
              ],
              "Application Containers": [
                "container-2"
              ],
              "Container Images": [
                "image/2.0"
              ]
            },
            {
              "EC2 Private IPv4 DNS Name": "compute.internal-3",
              "EC2 Private IPv4 address": "1.23.3.44",
              "Workloads": [
                "workload-1",
                "workload-2",
                "workload-3",
                "workload-4"
              ],
              "Application Pods": [
                "pod-1",
                "pod-2"
              ],
              "Application Containers": [
                "cnt-1",
                "cnt-2"
              ],
              "Container Images": [
                "image-1",
                "image-2"
              ]
            }
          ]
        }
      }
    ],
    "identifier": 73884180
  },
  {
    "context": [
      "I would really like to narrow this down to just superusers.",
      "If in your source document `.is_superuser` is a boolean value, your `select` expression should read `select(.is_superuser == true)` (which can be abbreviated as `select(.is_superuser)`), and not `select(.is_superuser == \"true\")` (which makes a comparison to the literal string \"true\").",
      ".User[]\n| select(.is_superuser)\n| {Username: .username, Full_name: .full_name, Superuser: .is_superuser, Active: .is_active}",
      "[\"Username\", \"Full name\", \"Superuser\", \"Active\"],\n(.User[]\n| select(.is_superuser)\n| [ .username, .full_name, .is_superuser, .is_active ])\n| @csv"
    ],
    "utterance": "Generate a CSV file listing only users who are superusers, including username, full name, superuser status, and active status.",
    "expressions": [
      ".User[]\n| select(.is_superuser)\n| {Username: .username, Full_name: .full_name, Superuser: .is_superuser, Active: .is_active}",
      ".User[]\n| select(.is_superuser)\n| [ .username, .full_name, .is_superuser, .is_active ]\n| @csv",
      "[\"Username\", \"Full name\", \"Superuser\", \"Active\"],\n(.User[]\n| select(.is_superuser)\n| [ .username, .full_name, .is_superuser, .is_active ])\n| @csv"
    ],
    "data": [
      {
        "input": {
          "User": [
            {
              "username": "name1",
              "full_name": "full_name",
              "is_superuser": true,
              "is_active": false
            },
            {
              "username": "name1",
              "full_name": "full_name",
              "is_superuser": false,
              "is_active": false
            },
            {
              "username": "name2",
              "full_name": "full_name",
              "is_superuser": true,
              "is_active": false
            },
            {
              "username": "name2",
              "full_name": "full_name",
              "is_superuser": false,
              "is_active": false
            }
          ]
        },
        "output": "\"Username\",\"Full name\",\"Superuser\",\"Active\"\n\"name1\",\"full_name\",true,false\n\"name2\",\"full_name\",true,false\n"
      }
    ],
    "identifier": 73945485
  },
  {
    "context": [
      "The idea is to delete 'error' field in every child, without specifying every field, only one general character, similar than equivalent in above yq.",
      "And this is my expectation:\n\n    {\n        \"body\": {\n            \"field1\":{\n                \"name\": \"test\",\n            },\n            \"field2\":{\n                \"name\":\"jose\"\n            },\n            \"field3\":{\n                \"name\":\"tere\",\n            }\n        }\n    }",
      "Try indexing with [] instead.\n```\ndel(.body[].error)\n```",
      "One way to delete every \"error\" field in every object:\n\n    jq 'del(..|objects|.error)'",
      "This removes `error` properties anywhere in your document:\n\n    del(..|.error?)"
    ],
    "utterance": "Remove every 'error' field from all direct child objects of the 'body' property.",
    "expressions": [
      "del(.body[].error)",
      "del(..|objects|.error)",
      "del(..|.error?)"
    ],
    "data": [
      {
        "input": {
          "body": {
            "field1": {
              "name": "test",
              "error": "messsage empty"
            },
            "field2": {
              "name": "jose"
            },
            "field3": {
              "name": "tere",
              "error": "messsage empty 2"
            }
          }
        },
        "output": {
          "body": {
            "field1": {
              "name": "test"
            },
            "field2": {
              "name": "jose"
            },
            "field3": {
              "name": "tere"
            }
          }
        }
      }
    ],
    "identifier": 73954010
  },
  {
    "context": [
      "I am trying to reduce an array \n[\n{\"cat\": \"low\", \"value\": \"1\"},\n{\"cat\": \"med\", \"value\": \"2\"},\n{\"cat\": \"med\", \"value\": \"3\"}\n]\nsuch that it produces this output:\n{\n  \"low\": [\n    {\n      \"cat\": \"low\",\n      \"value\": \"1\"\n    }\n  ],\n  \"med\": [\n    {\n      \"cat\": \"med\",\n      \"value\": \"2\"\n    },\n    {\n      \"cat\": \"med\",\n      \"value\": \"3\"\n    }\n  ]\n}",
      "With `reduce`, add the items to and as an array:\n~~~sh\njq 'reduce .[] as $curr ({}; .[$curr.cat] += [$curr])'\n~~~",
      "Alternatively, you can use `group_by`, then `add` the `map`ped items:\n~~~sh\njq 'group_by(.cat) | map({(first.cat): .}) | add'\n~~~",
      "The same can be achieved using `with_entries`:\n~~~sh\njq 'group_by(.cat) | with_entries(.key = .value[0].cat)'\n~~~",
      "Or even shorter, using `INDEX`:\n~~~sh\njq 'group_by(.cat) | INDEX(first.cat)'\n~~~"
    ],
    "utterance": "Group array elements by the value of 'cat' so that each key is a category and its value is an array of objects sharing that category.",
    "expressions": [
      "reduce .[] as $curr ({}; .[$curr.cat] += [$curr])",
      "group_by(.cat) | map({(first.cat): .}) | add",
      "group_by(.cat) | with_entries(.key = .value[0].cat)",
      "group_by(.cat) | INDEX(first.cat)"
    ],
    "data": [
      {
        "input": [
          {
            "cat": "low",
            "value": "1"
          },
          {
            "cat": "med",
            "value": "2"
          },
          {
            "cat": "med",
            "value": "3"
          }
        ],
        "output": {
          "low": [
            {
              "cat": "low",
              "value": "1"
            }
          ],
          "med": [
            {
              "cat": "med",
              "value": "2"
            },
            {
              "cat": "med",
              "value": "3"
            }
          ]
        }
      }
    ],
    "identifier": 73956418
  },
  {
    "context": [
      "With an input of:",
      "{\n    \"SomeValue\": {\n        \"x\" : \"y\",\n        \"a\" : \"b\"\n    }\n}",
      "I\u2019d like to be able to remove 'SomeValue' and return just the key/values below so that my output would look like:",
      "{\n    \"x\" : \"y\",\n    \"a\" : \"b\"\n}",
      "If all you want is the content of `.SomeValue`, that's already exactly your filter:\n~~~\njq '.SomeValue'\n~~~"
    ],
    "utterance": "Extract the values inside a top-level key named SomeValue, omitting the top-level key itself.",
    "expressions": [
      ".SomeValue"
    ],
    "data": [
      {
        "input": {
          "SomeValue": {
            "x": "y",
            "a": "b"
          }
        },
        "output": {
          "x": "y",
          "a": "b"
        }
      }
    ],
    "identifier": 73985189
  },
  {
    "context": [
      "Now I'm wondering: does `jq` have ability to filter out by regexp? For instance I'd like to dump only entries where IP is `192.168.1.*`, can it be done with jq? Ideally I'd like to pass regexp to my script as a parameter:",
      "You can use `test` with regular expressions, and `select` to filter:",
      "jq -r --arg addr \"192\\\\.168\\\\.1\\\\..*\" '\n  .[0] | select(.result == 0) | .arguments.leases[]\n  | \"\\(.[\"hw-address\"]) \\(.[\"ip-address\"] | select(test($addr)))\"\n'",
      "jq has [`test`](https://stedolan.github.io/jq/manual/v1.6/#test(val),test(regex;flags)) to test an input against a regular expression:",
      "jq -r --arg regex '^192\\.168\\.1\\.' 'first\n| select(.result == 0)\n| .arguments.leases[]\n| select(.\"ip-address\"|test($regex))\n| \"\\(.\"hw-address\") \\(.\"ip-address\")\"'"
    ],
    "utterance": "Output only entries where ip-address matches a provided regular expression, such as those starting with 192.168.1.",
    "expressions": [
      ".[0] | select(.result == 0) | .arguments.leases[] | select(.\"ip-address\" | test($addr)) | \"\\(.\"hw-address\") \\(.\"ip-address\")\"",
      "first | select(.result == 0) | .arguments.leases[] | select(.\"ip-address\"|test($regex)) | \"\\(.\"hw-address\") \\(.\"ip-address\")\""
    ],
    "data": [
      {
        "input": [
          {
            "arguments": {
              "leases": [
                {
                  "cltt": 1658763299,
                  "fqdn-fwd": false,
                  "fqdn-rev": false,
                  "hostname": "",
                  "hw-address": "00:aa:bb:cc:dd:ee",
                  "ip-address": "192.168.0.2",
                  "state": 0,
                  "subnet-id": 1,
                  "valid-lft": 3600
                },
                {
                  "cltt": 1658763207,
                  "fqdn-fwd": false,
                  "fqdn-rev": false,
                  "hostname": "",
                  "hw-address": "00:11:22:33:44:55",
                  "ip-address": "192.168.1.3",
                  "state": 0,
                  "subnet-id": 1,
                  "valid-lft": 3600
                }
              ]
            },
            "result": 0,
            "text": "2 IPv4 lease(s) found."
          }
        ],
        "output": "00:11:22:33:44:55 192.168.1.3"
      }
    ],
    "identifier": 73949045
  },
  {
    "context": [
      "How do I find out how many key value pairs are in it?",
      "You can use `jq 'keys | length'`, which will do exactly the same as `Object.keys(myJson).length`.",
      "Just use `length` directly on the object.",
      "The length of an object is the number of key-value pairs",
      "{ \"foo\":\"bar\", \"baz\":5, \"qux\":false } | length",
      "If the object is the input to JQ, then simply `length`:\n    echo '{\"a\":4,\"b\":2}' | jq 'length'"
    ],
    "utterance": "Count the number of key-value pairs in the top-level object.",
    "expressions": [
      "keys | length",
      "length"
    ],
    "data": [
      {
        "input": {
          "foo": "bar",
          "baz": 5,
          "qux": false
        },
        "output": 3
      },
      {
        "input": {
          "a": 4,
          "b": 2
        },
        "output": 2
      }
    ],
    "identifier": 73960114
  },
  {
    "context": [
      "I have tried to adjust it so that I can use the same concept but to get other information and have this",
      "I receive the error below",
      "If it helps this is an extract from the JSON with fields that aren't relevant removed but all formatting kept",
      "[\"Interface Name\", \"Vlan ID\", \"IP address\", \"Subnet Mask\"],",
      "(\n    .ServiceEngine[].data_vnics[].vlan_interfaces[]\n    | . as { $if_name, $vlan_id }\n    | .vnic_networks[].ip\n    | [ $if_name, $vlan_id, .ip_addr.addr, .mask]\n)\n| @csv",
      "All three generate the same CSV with one line per IP. Interface name and VLAN id will be printed multiple times if they contain more than one IP."
    ],
    "utterance": "Extract rows for each interface including its name, vlan id, ip address, and subnet mask in CSV format, with one row per IP.",
    "expressions": [
      "[\"Interface Name\", \"Vlan ID\", \"IP address\", \"Subnet Mask\"],\n(\n    .ServiceEngine[].data_vnics[].vlan_interfaces[]\n    | . as { $if_name, $vlan_id }\n    | .vnic_networks[].ip\n    | [ $if_name, $vlan_id, .ip_addr.addr, .mask]\n)\n| @csv",
      "[\"Interface Name\", \"Vlan ID\", \"IP address\", \"Subnet Mask\"],\n(\n    .ServiceEngine[].data_vnics[].vlan_interfaces[]\n    | [ .if_name, .vlan_id ] + (.vnic_networks[].ip | [.ip_addr.addr, .mask])\n)\n| @csv",
      "[\"Interface Name\", \"Vlan ID\", \"IP address\", \"Subnet Mask\"],\n(\n    .ServiceEngine[].data_vnics[].vlan_interfaces[]\n    | { if_name, vlan_id, ips: .vnic_networks[].ip }\n    | [ .if_name, .vlan_id, (.ips|.ip_addr.addr, .mask) ]\n)\n| @csv"
    ],
    "data": [
      {
        "input": {
          "ServiceEngine": [
            {
              "data_vnics": [
                {
                  "vlan_interfaces": [
                    {
                      "if_name": "bond1.109",
                      "vlan_id": 109,
                      "vnic_networks": [
                        {
                          "ctlr_alloc": false,
                          "ip": {
                            "ip_addr": {
                              "addr": "123.123.123.123",
                              "type": "V4"
                            },
                            "mask": 24
                          },
                          "mode": "STATIC"
                        }
                      ],
                      "vrf_ref": "/api/vrfcontext/?tenant=admin&name=branch-pci-client-vlan109&cloud=Default-Cloud"
                    },
                    {
                      "dhcp_enabled": true,
                      "enabled": true,
                      "if_name": "bond1.1622",
                      "ip6_autocfg_enabled": true,
                      "is_mgmt": false,
                      "vlan_id": 1622,
                      "vnic_networks": [
                        {
                          "ctlr_alloc": false,
                          "ip": {
                            "ip_addr": {
                              "addr": "456.456.456.456",
                              "type": "V4"
                            },
                            "mask": 22
                          },
                          "mode": "STATIC"
                        }
                      ],
                      "vrf_ref": "/api/vrfcontext/?tenant=admin&name=onprem-pci-prod-vlan1622&cloud=Default-Cloud"
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": "\"Interface Name\",\"Vlan ID\",\"IP address\",\"Subnet Mask\"\n\"bond1.109\",109,\"123.123.123.123\",24\n\"bond1.1622\",1622,\"456.456.456.456\",22"
      }
    ],
    "identifier": 73948046
  },
  {
    "context": [
      "By help of bash and jq I like to concat a string of the second level keys `index.md` and `user_profile.md`. Further I like replace `.md` with `.html` (key admin-user is unknown an can change)",
      "So the result is an array. How can I concat a string with blanks between strings?",
      "which you can then -still in jq- concatenate using `join` and a glue character:",
      "jq -r 'map(keys_unsorted[] | sub(\"\\.md$\"; \".html\")) | join(\" \")' test.json",
      "jq -r 'map(to_entries[].key | sub(\"\\.md$\"; \".html\")) | join(\" \")' test.json"
    ],
    "utterance": "Concatenate all second-level keys with the '.md' extension replaced by '.html', joining them with spaces, for any top-level key.",
    "expressions": [
      "map(keys_unsorted[] | sub(\"\\.md$\"; \".html\")) | join(\" \")",
      "map(to_entries[].key | sub(\"\\.md$\"; \".html\")) | join(\" \")"
    ],
    "data": [
      {
        "input": {
          "admin-user": {
            "index.md": "Index",
            "user_profil.md": "User Profil"
          }
        },
        "output": "index.html user_profil.html"
      }
    ],
    "identifier": 73960343
  },
  {
    "context": [
      "How do I not display the key `put` just because it has child key `\"deprecated\": true`?",
      "To filter out certain elements, you can beforehand update items (not) matching your criteria:",
      "jq '.paths | .[][] |= select(.deprecated | not) | .[] |= keys_unsorted'",
      "Or the two steps combined:",
      "jq '.paths | .[] |= (.[] |= select(.deprecated | not) | keys_unsorted)'",
      "Note: Referring to your own approach, if you prefer using `keys` over `keys_unsorted` (the former will additionally sort the output list), and `map_values` over `.[] |=` (they are identical), my approach would translate to:",
      "jq '.paths | map_values(map_values(select(.deprecated | not)) | keys)'"
    ],
    "utterance": "List all API method names under each path, excluding any method where the 'deprecated' field is true.",
    "expressions": [
      ".paths | .[][] |= select(.deprecated | not) | .[] |= keys_unsorted",
      ".paths | .[] |= (.[] |= select(.deprecated | not) | keys_unsorted)",
      ".paths | map_values(map_values(select(.deprecated | not)) | keys)"
    ],
    "data": [
      {
        "input": {
          "paths": {
            "/api/A": {
              "get": {
                "summary": "lorem ipsum",
                "parameters": [
                  {
                    "name": "Guid",
                    "description": "Guid"
                  }
                ]
              },
              "put": {
                "summary": "Adds or updates an item",
                "parameters": [
                  {
                    "name": "lorem ipsum",
                    "description": "lorem ipsum"
                  }
                ],
                "deprecated": true
              }
            }
          }
        },
        "output": {
          "/api/A": [
            "get"
          ]
        }
      }
    ],
    "identifier": 73985783
  },
  {
    "context": [
      "I want to update the value of key. For example games to 66. So the new file would be:\n\n    { \"test\": \"10\" }\n    { \"games\": \"66\" }\n    { \"REPOSITORY\":\"5\"}",
      "To update the specific object alone, select it first and assign the required value or update it.",
      "jq -c 'select(has(\"games\")).games = \"66\"'",
      "A simple solution is using select with assignment. select will return the special value empty if the condition does not match and the input value if it does match.",
      "select(.games).games = \"66\""
    ],
    "utterance": "Update the value of the 'games' key to 66 only in the object that contains it, keeping all other objects unchanged.",
    "expressions": [
      "jq -c 'select(has(\"games\")).games = \"66\"'",
      "jq -c 'select(.games).games = \"66\"'",
      "jq -c 'select([\"games\"])[\"games\"] = \"66\"'"
    ],
    "data": [
      {
        "input": [
          {
            "test": "10"
          },
          {
            "games": "30"
          },
          {
            "REPOSITORY": "5"
          }
        ],
        "output": [
          {
            "test": "10"
          },
          {
            "games": "66"
          },
          {
            "REPOSITORY": "5"
          }
        ]
      }
    ],
    "identifier": 73987116
  },
  {
    "context": [
      "I can't seem to figure out how to allow the area to be null if `.in` or `.in.id` is null.",
      "Using `?` makes the error go away but it's still only the first item",
      ".[] | {section:.a, area_or_null:(.in[]?.id//null)}",
      "Output:",
      "{",
      "  \"section\": 1,",
      "  \"area_or_null\": 2",
      "}",
      "{",
      "  \"section\": 4,",
      "  \"area_or_null\": null",
      "}"
    ],
    "utterance": "For each object, return its section field and the id of the first element in in if it exists, otherwise null.",
    "expressions": [
      ".[] | {section:.a, area_or_null:(.in[]?.id//null)}"
    ],
    "data": [
      {
        "input": [
          {
            "a": 1,
            "in": [
              {
                "id": 2
              }
            ]
          },
          {
            "a": 4
          }
        ],
        "output": [
          {
            "section": 1,
            "area_or_null": 2
          },
          {
            "section": 4,
            "area_or_null": null
          }
        ]
      }
    ],
    "identifier": 73994331
  },
  {
    "context": [
      "i need to use jq on an Json file and find match for \"status\" : \"failed\" in file",
      "jq -r '.'' *.json | jq '(.steps) |= []' | grep -c '\"status\": \"failed\"'"
    ],
    "utterance": "Count the number of occurrences where status is failed across multiple files.",
    "expressions": [
      "jq -r '.'' *.json | jq '(.steps) |= []' | grep -c '\"status\": \"failed\"'",
      "jq -r 'select(.status == \"failed\")' *.json | wc -l"
    ],
    "identifier": 73995671
  },
  {
    "context": [
      "But I *want* it to look like...\r\n\r\n    [\r\n      {\r\n        \"a\": \"1\",\r\n        \"blah\": \"true\"\r\n      }\r\n      {\r\n        \"c\": \"3\",\r\n        \"blah\": \"true\"\r\n      }\r\n    ]\r\n\r\n...this, so that I can use indexing to get certain of these entries. How do I do that?",
      "Simply indicate you want the result in a list by wrapping the expression with [];",
      "cat test.json | jq '[.[] | select(.blah==\"true\")]'",
      "Using `map` to iterate over the array\n```sh\njq 'map(select(.blah == \"true\"))'\n```",
      "Using param -s:\n\n    jq  '.[]|select(.blah==\"true\")' | jq -s '.'"
    ],
    "utterance": "Return the elements where the blah field equals \"true\" as a list so they can be indexed.",
    "expressions": [
      "[.[] | select(.blah==\"true\")]",
      "map(select(.blah == \"true\"))"
    ],
    "data": [
      {
        "input": [
          {
            "a": "1",
            "blah": "true"
          },
          {
            "b": "2",
            "blah": "false"
          },
          {
            "c": "3",
            "blah": "true"
          }
        ],
        "output": [
          {
            "a": "1",
            "blah": "true"
          },
          {
            "c": "3",
            "blah": "true"
          }
        ]
      }
    ],
    "identifier": 73992039
  },
  {
    "context": [
      "I want a to check if the json object has an attribute named \"address\" is present. Also how to get value of the attribute address . I want to use jq library",
      "`jq '.address'` will output the value of the property `value`, e.g. `\"192.168.123.1\"`. (`jq -r` to get rid of the quote marks)",
      "`jq 'has(\"address\")'` will output `true`/`false`",
      "`jq -e 'has(\"address\")' > /dev/null` will set the process' exit status to `0`/`1` depending on the object having the key \"address\" (regardless of value)",
      "`jq -e '.address' > /dev/null` will set the process' exit status to `0` if the \"address\" property has a _truthy_ value (anything except `null` or `false`). A `null` or `false` valued property will set the exit code to `1`."
    ],
    "utterance": "Check whether the object has an attribute named 'address' and retrieve its value.",
    "expressions": [
      ".address",
      "has(\"address\")"
    ],
    "data": [
      {
        "input": {
          "content-length": "2",
          "address": "192.168.123.1",
          "path": "/hello-world"
        },
        "output": "192.168.123.1"
      }
    ],
    "identifier": 73998004
  },
  {
    "context": [
      "My input is\n\n    [\n      {\n        \"PartNumber\": \"5SD30104GN114\",\n        \"ClassificationNo\": \"500001\",\n        \"StringValue\": \"L0035WSGE\",\n        \"Field\": \"95001\"\n      },\n      {\n        \"PartNumber\": \"5SD30104GN114\",\n        \"ClassificationNo\": \"500001\",\n        \"StringValue\": \"\",\n        \"Field\": \"95002\"\n      }\n    ]\n\nAnd I like to expect this\n\n    [\n      {\n        \"PartNumber\": \"5SD30104GN114\",\n        \"ClassificationNo\": \"500001\",\n        \"95001\": \"L0035WSGE\",\n        \"95002\": \"\",\n      }\n    ]",
      "You can use `group_by` to make clusters of matching IDs (I assumed `.PartNumber` together with `.ClassificationNo` to make a unique ID), then within each cluster, take the ID fields from the first item (all have the same ID fields), and add to it the values of all items by converting them to a key-value structure that can be used with `from_entries` to turn it into an object:",
      "group_by([.PartNumber, .ClassificationNo]) | map(\n  (first | {PartNumber, ClassificationNo}) +\n  (map({key: .Field, value: .StringValue}) | from_entries)\n)",
      "Instead of `from_entries`, you can also use `INDEX` to create an object with the right fields, but then subsequently the values need to be trimmed down to only contain the right values:",
      "group_by([.PartNumber, .ClassificationNo]) | map(\n  (first | {PartNumber, ClassificationNo}) +\n  (INDEX(.Field) | .[] |= .StringValue)\n)",
      "Here's a solution using reduce:\n\ngroup_by({PartNumber,ClassificationNo})\n| map(reduce .[] as $item ({}; .+($item|{PartNumber, ClassificationNo, (.Field):.StringValue})))"
    ],
    "utterance": "Transform an array of objects with PartNumber, ClassificationNo, Field, and StringValue so that for each unique PartNumber and ClassificationNo, create a single object where each Field becomes a key with its corresponding StringValue as the value.",
    "expressions": [
      "group_by([.PartNumber, .ClassificationNo]) | map((first | {PartNumber, ClassificationNo}) + (map({key: .Field, value: .StringValue}) | from_entries))",
      "group_by([.PartNumber, .ClassificationNo]) | map((first | {PartNumber, ClassificationNo}) + (INDEX(.Field) | .[] |= .StringValue))",
      "group_by({PartNumber,ClassificationNo}) | map(reduce .[] as $item ({}; .+($item|{PartNumber, ClassificationNo, (.Field):.StringValue})))"
    ],
    "data": [
      {
        "input": [
          {
            "PartNumber": "5SD30104GN114",
            "ClassificationNo": "500001",
            "StringValue": "L0035WSGE",
            "Field": "95001"
          },
          {
            "PartNumber": "5SD30104GN114",
            "ClassificationNo": "500001",
            "StringValue": "",
            "Field": "95002"
          }
        ],
        "output": [
          {
            "PartNumber": "5SD30104GN114",
            "ClassificationNo": "500001",
            "95001": "L0035WSGE",
            "95002": ""
          }
        ]
      }
    ],
    "identifier": 73986020
  },
  {
    "context": [
      "I am also using jq library to handle the json data. In the above example i want the content-length value in the x_header variable",
      "function getHeader() {\r\n  jq \".\\\"$1\\\"\" <<< \"$2\"\r\n}\r\n\r\nresponse='{\"content-length\":\"2\",\"address\":\"10.244.3.1:37930\",\"path\":\"/hello-world\"}'\r\n\r\nx_header=$(getHeader  \"content-length\" \"$response\" )"
    ],
    "utterance": "Extract the value of the content-length key from the given object.",
    "expressions": [
      ".\"content-length\""
    ],
    "data": [
      {
        "input": {
          "content-length": "2",
          "address": "10.244.3.1:37930",
          "path": "/hello-world"
        },
        "output": "2"
      }
    ],
    "identifier": 74004219
  },
  {
    "context": [
      "But using the analogous command for the \"name\" or \"age\" keys gives an empty result:",
      "$ jq -cn --stream \u2018fromstream(1|truncate_stream(inputs | select(.[0][0] == \"name\")))\u2019 <sample.json",
      "$ jq -cn --stream \u2018fromstream(1|truncate_stream(inputs | select(.[0][0] == \"age\")))\u2019 <sample.json",
      "So it looks like these values are being selected, but they are just not making it through to the output.",
      "So for simple scalars, simply extract away the value from the indices as below without needing to use truncate at all",
      "jq -cn --stream 'inputs|select(.[0][0] == \"age\")[1]'",
      "51"
    ],
    "utterance": "Extract the value associated with the top-level key \"age\" when streaming.",
    "expressions": [
      "inputs | select(.[0][0] == \"age\")[1]"
    ],
    "data": [
      {
        "input": {
          "empty": null,
          "name": "John Smith",
          "sex": "male",
          "age": 51,
          "hobbies": [
            "running",
            "kayaking",
            "camping",
            "foraging"
          ]
        },
        "output": 51
      }
    ],
    "identifier": 74010890
  },
  {
    "context": [
      "however I want this (note double quotes around `this is a string`):",
      "export let stringKey = \"this is a string\"",
      "Use [`tojson`](https://stedolan.github.io/jq/manual/#Convertto/fromJSON), not `tostring`. It does exactly what you need for all data types.",
      "jq -r 'to_entries[] | \"export let \" + .key + \" = \" + (.value | tojson)'",
      "you can also use the `@json` syntax and provide the value through string interpolation:\n~~~sh\njq -r 'to_entries[] | \"export let \" + .key + @json \" = \\(.value)\"'\n~~~"
    ],
    "utterance": "Output each top-level key/value pair as 'export let <key> = <value>', with string values wrapped in double quotes and non-strings unquoted, preserving JSON formatting.",
    "expressions": [
      "to_entries | map(\"export let \" + .key + \" = \" + (.value | tojson)) | .[]",
      "to_entries[] | \"export let \" + .key + \" = \" + (.value | tojson)",
      "to_entries[] | \"export let \" + .key + @json \" = \\(.value)\""
    ],
    "data": [
      {
        "input": {
          "stringKey": "this is a string",
          "numberKey": 1234,
          "jsonKey": [
            {
              "numberKey": 1,
              "stringKey": "0x"
            }
          ]
        },
        "output": [
          "export let stringKey = \"this is a string\"",
          "export let numberKey = 1234",
          "export let jsonKey = [{\"numberKey\":1,\"stringKey\":\"0x\"}]"
        ]
      }
    ],
    "identifier": 74003358
  },
  {
    "context": [
      "# expected output",
      "{",
      "  \"listoffiles\": [",
      "    {\"file\":\"myawesomeprefix/file1.txt\"},",
      "    {\"file\":\"myawesomeprefix/file2.txt\"},",
      "    {\"file\":\"myawesomeprefix/file3.txt\"},",
      " ]",
      "}",
      "ls -1 | jq -Rn '{ listoffiles: [inputs | { file: \"prefix/\\(.)\" }] }'",
      "tree -aJL 1 | jq '{listoffiles: first.contents | map({file: (\"myawesomeprefix/\" + .name)})}'",
      "jq -n --arg prefix \"myawesomeprefix\" '.listoffiles = ($ARGS.positional | map({file:($prefix+\"/\"+.)}))' --args *"
    ],
    "utterance": "Create an object with a key 'listoffiles' whose value is an array of objects each containing the key 'file' with a value consisting of the prefix 'myawesomeprefix/' followed by each file name in the target directory.",
    "expressions": [
      "ls -1 | jq -Rn '{ listoffiles: [inputs | { file: \"myawesomeprefix/\\(.)\" }] }'",
      "jq -n --arg prefix \"myawesomeprefix\" '.listoffiles = ($ARGS.positional | map({file:($prefix+\"/\"+.)}))' --args *",
      "tree -aJL 1 | jq '{listoffiles: first.contents | map({file: (\"myawesomeprefix/\" + .name)})}'",
      "tree -aJL 1 | jq --arg prefix myawesomeprefix '{listoffiles: first.contents | map({file: \"\\($prefix)/\\(.name)\"})}'"
    ],
    "data": [
      {
        "input": [
          "file1.txt",
          "file2.txt",
          "file3.txt"
        ],
        "output": {
          "listoffiles": [
            {
              "file": "myawesomeprefix/file1.txt"
            },
            {
              "file": "myawesomeprefix/file2.txt"
            },
            {
              "file": "myawesomeprefix/file3.txt"
            }
          ]
        }
      }
    ],
    "identifier": 74011653
  },
  {
    "context": [
      "its huge number of list how can we find out all groups, its more than 30 seems. and iterate through it to find out ID of group?",
      "grouplist=$(curl --header \"PRIVATE-TOKEN: $1\" \"https://gitlab.com/api/v4/groups?per_page=100&page=30\" | jq -r '[].id')",
      "The retrieved JSON documents can then can be fed to jq."
    ],
    "utterance": "Extract the ID of each group from the results returned by the API.",
    "expressions": [
      ".[].id"
    ],
    "identifier": 74023537
  },
  {
    "context": [
      "I want to filter only these below values (that is available under \"text\" field). I want to use the jq command for this.",
      "Expected result:",
      "    23.acmestable.0.22",
      "    23.acmestable.0.23",
      "    23.acmestable.0.24",
      "    23.acmestable.0.25",
      "Just traverse and `select` in a single jq call. The `?` filters out the `null` values.",
      "jq -r '[].content.data[].\"content-item\"[].text | select(startswith(\"23.acmestable.0.\"))?'"
    ],
    "utterance": "Extract all values from the text field that start with 23.acmestable.0.",
    "expressions": [
      ".[].content.data[].\"content-item\"[].text | select(startswith(\"23.acmestable.0.\"))?"
    ],
    "data": [
      {
        "input": [
          {
            "content": {
              "data": [
                {
                  "content-item": [
                    {
                      "resourceURI": "https://acme.example.com/service/local/repositories/public/content/com/acme/acme-files/23.acmestable.0.0-SNAPSHOT/"
                    },
                    {
                      "relativePath": "/com/acme/acme-files/23.acmestable.0.0-SNAPSHOT/"
                    },
                    {
                      "text": "23.acmestable.0.0-SNAPSHOT"
                    },
                    {
                      "leaf": "false"
                    },
                    {
                      "lastModified": "2022-10-06 11:54:58.0 UTC"
                    },
                    {
                      "sizeOnDisk": "-1"
                    }
                  ]
                },
                {
                  "content-item": [
                    {
                      "resourceURI": "https://acme.example.com/service/local/repositories/public/content/com/acme/acme-files/23.acmestable.0.24/"
                    },
                    {
                      "relativePath": "/com/acme/acme-files/23.acmestable.0.24/"
                    },
                    {
                      "text": "23.acmestable.0.24"
                    },
                    {
                      "leaf": "false"
                    },
                    {
                      "lastModified": "2022-10-07 03:17:23.0 UTC"
                    },
                    {
                      "sizeOnDisk": "-1"
                    }
                  ]
                },
                {
                  "content-item": [
                    {
                      "resourceURI": "https://acme.example.com/service/local/repositories/public/content/com/acme/acme-files/23.acmestable.0.25/"
                    },
                    {
                      "relativePath": "/com/acme/acme-files/23.acmestable.0.25/"
                    },
                    {
                      "text": "23.acmestable.0.25"
                    },
                    {
                      "leaf": "false"
                    },
                    {
                      "lastModified": "2022-10-07 03:17:23.0 UTC"
                    },
                    {
                      "sizeOnDisk": "-1"
                    }
                  ]
                },
                {
                  "content-item": [
                    {
                      "resourceURI": "https://acme.example.com/service/local/repositories/public/content/com/acme/acme-files/23.acmestable.0.22/"
                    },
                    {
                      "relativePath": "/com/acme/acme-files/23.acmestable.0.22/"
                    },
                    {
                      "text": "23.acmestable.0.22"
                    },
                    {
                      "leaf": "false"
                    },
                    {
                      "lastModified": "2022-10-07 03:17:23.0 UTC"
                    },
                    {
                      "sizeOnDisk": "-1"
                    }
                  ]
                },
                {
                  "content-item": [
                    {
                      "resourceURI": "https://acme.example.com/service/local/repositories/public/content/com/acme/acme-files/23.acmestable.0.23/"
                    },
                    {
                      "relativePath": "/com/acme/acme-files/23.acmestable.0.23/"
                    },
                    {
                      "text": "23.acmestable.0.23"
                    },
                    {
                      "leaf": "false"
                    },
                    {
                      "lastModified": "2022-10-07 03:17:23.0 UTC"
                    },
                    {
                      "sizeOnDisk": "-1"
                    }
                  ]
                }
              ]
            }
          }
        ],
        "output": [
          "23.acmestable.0.0-SNAPSHOT",
          "23.acmestable.0.24",
          "23.acmestable.0.25",
          "23.acmestable.0.22",
          "23.acmestable.0.23"
        ]
      }
    ],
    "identifier": 74000292
  },
  {
    "context": [
      "I want to get the difference between each array, looks like\n1665129236,1\n1665129266,1\n1665129296,5",
      ".values | [.[:-1], .[1:]] | transpose[]\n| \"\\(.[1][0]),\\(map(.[1] | tonumber) | .[1]-.[0])\"",
      ".values | foreach .[1:][] as $v ([null, .[0]]; .[1:] + [$v];\n  \"\\(.[1][0]),\\(map(.[1] | tonumber) | .[1]-.[0])\"\n)",
      ".values | while(has(1); .[1:])[:2]\n| \"\\(.[1][0]),\\(map(.[1] | tonumber) | .[1]-.[0])\""
    ],
    "utterance": "Get the difference of the second element between each consecutive pair in the 'values' array, outputting the timestamp and the computed difference for each pair.",
    "expressions": [
      ".values | [.[:-1], .[1:]] | transpose[] | \"\\(.[1][0]),\\(map(.[1] | tonumber) | .[1]-.[0])\"",
      ".values | foreach .[1:][] as $v ([null, .[0]]; .[1:] + [$v]; \"\\(.[1][0]),\\(map(.[1] | tonumber) | .[1]-.[0])\")",
      ".values | while(has(1); .[1:])[:2] | \"\\(.[1][0]),\\(map(.[1] | tonumber) | .[1]-.[0])\""
    ],
    "data": [
      {
        "input": {
          "metric": {
            "instance": "100.120.207.215:8081",
            "job": "job1",
            "error_code": "500"
          },
          "values": [
            [
              1665129206,
              "128"
            ],
            [
              1665129236,
              "129"
            ],
            [
              1665129266,
              "130"
            ],
            [
              1665129296,
              "135"
            ]
          ]
        },
        "output": [
          "1665129236,1",
          "1665129266,1",
          "1665129296,5"
        ]
      }
    ],
    "identifier": 74012228
  },
  {
    "context": [
      "I need to recursively go through them and check to see if any parent has children keys ```a``` or ```b```, or both, and generate the JSON path to that parent like so:",
      "Output:\r\nparent2 \r\nparent3.child1\r\nparent3.child2",
      "If you don't want the last key, you could add `[:-1]` to 'remove' the last index in each array to output: ",
      "path(..) | select(index(\"a\") or index(\"b\"))[:-1] | join(\".\")",
      "\"parent2\"",
      "\"parent3.child1\"",
      "\"parent3.child2\""
    ],
    "utterance": "List all object paths whose direct children include the keys 'a' or 'b'.",
    "expressions": [
      "path(..) | select(index(\"a\") or index(\"b\"))[:-1] | join(\".\")"
    ],
    "data": [
      {
        "input": {
          "parent1": "someval",
          "parent2": {
            "a": "someval",
            "b": "someval"
          },
          "parent3": {
            "child1": {
              "a": "someval"
            },
            "child2": {
              "b": "someval"
            }
          }
        },
        "output": [
          "parent2",
          "parent2",
          "parent3.child1",
          "parent3.child2"
        ]
      }
    ],
    "identifier": 74020796
  },
  {
    "context": [
      "I have a json file like the one above, and I want to output the value of Name in one line including spaces.",
      "but I want to output the value as follows using the Name key.",
      "cat dog",
      "How can I output a single line including single spaces for each value in a json file?",
      "Just join them?",
      "jq -r '.entries | map(.Name) | join(\" \")' test.json"
    ],
    "utterance": "Output all Name values from entries on a single line separated by spaces.",
    "expressions": [
      ".entries | map(.Name) | join(\" \")"
    ],
    "data": [
      {
        "input": {
          "entries": [
            {
              "Name": "cat",
              "size": "100"
            },
            {
              "Name": "dog",
              "size": "200"
            }
          ]
        },
        "output": "cat dog"
      }
    ],
    "identifier": 74037727
  },
  {
    "context": [
      "Now how to check if the value of hello equals to saysay when it is a string variable ?",
      "when i try this one, I've got the following error : (23) Failed writing body",
      "curl url | jq -r '.properties.$variable[]==\"saysay\"'",
      "You can use `--arg` to set a jq variable from the command line.",
      "field=hello",
      "curl url | jq --arg property \"$field\" '.properties[$property][] == \"saysay\"'"
    ],
    "utterance": "Check if the property specified by a shell variable equals 'saysay'.",
    "expressions": [
      ".properties[$property][] == \"saysay\""
    ],
    "data": [
      {
        "input": {
          "properties": {
            "hello": [
              "saysay"
            ],
            "test": [
              "1"
            ]
          },
          "uri": "uri"
        },
        "output": true
      }
    ],
    "identifier": 74039101
  },
  {
    "context": [
      "I have two files containing json arrays like so",
      "**file1.json**",
      "[",
      "  {",
      "    \"classid\":\"abc\",",
      "    \"name\":\"Alex\"",
      "  },",
      "  {",
      "    \"classid\":\"abc\",",
      "    \"name\":\"Bob\"",
      "  }",
      "]",
      "**file2.json**",
      "[",
      "  {",
      "    \"classid\":\"abc\",",
      "    \"classname\":\"math\"",
      "  }",
      "]",
      "I'd like to combine these two files on \"classid\".",
      "Desired **output.json**",
      "[",
      "  {",
      "    \"classid\":\"abc\",",
      "    \"name\":\"Alex\",",
      "    \"classname\":\"math",
      "  },",
      "  {",
      "    \"classid\":\"abc\",",
      "    \"name\":\"Bob\",",
      "    \"classname\":\"math",
      "  }",
      "]",
      "If you have jq 1.6, just use `JOIN` with an `INDEX`:",
      "jq '[JOIN(INDEX(input[]; .classid); .[]; .classid; add)]' file1.json file2.json"
    ],
    "utterance": "Merge two arrays of objects from separate files, adding fields from objects with the same classid.",
    "expressions": [
      "[JOIN(INDEX(input[]; .classid); .[]; .classid; add)]"
    ],
    "data": [
      {
        "input": [
          [
            {
              "classid": "abc",
              "name": "Alex"
            },
            {
              "classid": "abc",
              "name": "Bob"
            }
          ],
          [
            {
              "classid": "abc",
              "classname": "math"
            }
          ]
        ],
        "output": [
          {
            "classid": "abc",
            "name": "Alex",
            "classname": "math"
          },
          {
            "classid": "abc",
            "name": "Bob",
            "classname": "math"
          }
        ]
      }
    ],
    "identifier": 74038570
  },
  {
    "context": [
      "if address == 1.1.1.1 then weight 0",
      "that's what i expect",
      "(.[].origins[] | select(.address == \"1.1.1.1\") | .weight ) |= 0",
      "(.[].origins[] | select(.address == \"1.1.1.1\")).weight = 0\n| map({name, origins})",
      "map(\n  {name, origins}\n  | .origins[] |= (select(.address == \"1.1.1.1\").weight = 0)\n)",
      "map({\n    name,\n    origins: .origins | map(select(.address==\"1.1.1.1\").weight = 0)\n})",
      "map( {name, origins} \n     | .origins |= map( if .address == \"1.1.1.1\" then .weight = 0 else . end) )"
    ],
    "utterance": "Set weight to 0 for all origins with address equal to 1.1.1.1, and output only name and origins fields for each object.",
    "expressions": [
      "(.[].origins[] | select(.address == \"1.1.1.1\")).weight = 0 | map({name, origins})",
      "map(\n  {name, origins}\n  | .origins[] |= (select(.address == \"1.1.1.1\").weight = 0)\n)",
      "map({\n    name,\n    origins: .origins | map(select(.address==\"1.1.1.1\").weight = 0)\n})",
      "map( {name, origins} \n     | .origins |= map( if .address == \"1.1.1.1\" then .weight = 0 else . end) )"
    ],
    "data": [
      {
        "input": [
          {
            "description": "",
            "created_on": "2021-12-27T11:32:03.171682Z",
            "modified_on": "2021-12-27T11:32:03.171682Z",
            "id": "test",
            "enabled": true,
            "minimum_origins": 1,
            "monitor": "test",
            "name": "test",
            "notification_email": "",
            "check_regions": null,
            "latitude": 43.7417,
            "longitude": -79.3733,
            "notification_filter": {
              "pool": {}
            },
            "healthy": true,
            "origins": [
              {
                "name": "AAAA",
                "address": "1.1.1.1",
                "enabled": true,
                "weight": 1,
                "healthy": true,
                "failure_reason": "No failures"
              },
              {
                "name": "BBBB",
                "address": "2.2.2.2",
                "enabled": true,
                "weight": 1,
                "healthy": true,
                "failure_reason": "No failures"
              }
            ]
          }
        ],
        "output": [
          {
            "name": "test",
            "origins": [
              {
                "name": "AAAA",
                "address": "1.1.1.1",
                "enabled": true,
                "weight": 0,
                "healthy": true,
                "failure_reason": "No failures"
              },
              {
                "name": "BBBB",
                "address": "2.2.2.2",
                "enabled": true,
                "weight": 1,
                "healthy": true,
                "failure_reason": "No failures"
              }
            ]
          }
        ]
      }
    ],
    "identifier": 74027159
  },
  {
    "context": [
      "- I then want to select a random relay in the relay array, or 1 random relay in each cities relay array, which is where I am getting stuck.",
      "- After I get a random relay in that/each array, I want to print certain values based on the key (i.e. ipvr_addr_in and public_key), in a csv format (for now).",
      "Here's one very simple jq-only implementation of your script importing the $RANDOM variable from bash...",
      "jq --arg country_choice \"$country_choice\" --argjson country_random $RANDOM \\",
      "  --arg city_choice \"$city_choice\" --argjson city_random $RANDOM \\",
      "  --argjson relay_random $RANDOM -r \\",
      "  '\n    .countries\n    | if $country_choice == \"\"\n      then .[$country_random % length]\n      else .[] | select(.name == $country_choice) end\n    \n    | .cities\n    | if $city_choice == \"\"\n      then .[$city_random % length]\n      else .[] | select(.name == $city_choice) end\n    \n    | .relays | .[$relay_random % length]\n    | .ipv4_addr_in + \",\" + .public_key\n  '",
      "146.70.133.98,Q2khJLbTSFxmppPGHgq2HdxMQx7CczPZCgVpYZMoNnM="
    ],
    "utterance": "Select a random relay from the relay list for the specified country and optional city, and output its ipv4_addr_in and public_key separated by a comma.",
    "expressions": [
      ".countries | if $country_choice == \"\" then .[$country_random % length] else .[] | select(.name == $country_choice) end | .cities | if $city_choice == \"\" then .[$city_random % length] else .[] | select(.name == $city_choice) end | .relays | .[$relay_random % length] | .ipv4_addr_in + \",\" + .public_key"
    ],
    "data": [
      {
        "input": {
          "countries": [
            {
              "name": "UK",
              "code": "gb",
              "cities": [
                {
                  "name": "London",
                  "code": "lon",
                  "relays": [
                    {
                      "hostname": "gb4-wireguard",
                      "ipv4_addr_in": "141.98.252.130",
                      "ipv6_addr_in": "2a03:1b20:7:f011::a01f",
                      "public_key": "IJJe0TQtuQOyemL4IZn6oHEsMKSPqOuLfD5HoAWEPTY="
                    },
                    {
                      "hostname": "gb5-wireguard",
                      "ipv4_addr_in": "141.98.252.222",
                      "ipv6_addr_in": "2a03:1b20:7:f011::a02f",
                      "public_key": "J57ba81Q8bigy9RXBXvl0DgABTrbl81nb37GuX50gnY="
                    },
                    {
                      "hostname": "gb-lon-wg-101",
                      "ipv4_addr_in": "146.70.119.66",
                      "ipv6_addr_in": "2001:ac8:31:f007::a39f",
                      "public_key": "MPZX0ZQtB5r1pmcvIcsAt1AMvenios2ICBz9rjbN/l4="
                    }
                  ]
                },
                {
                  "name": "Manchester",
                  "code": "mnc",
                  "relays": [
                    {
                      "hostname": "gb45-wireguard",
                      "ipv4_addr_in": "146.70.133.34",
                      "ipv6_addr_in": "2001:ac8:8b:2b::a45f",
                      "public_key": "v+dOPx0FM8lGCjJ7m/7miWy67PGuazYYzvJoeMb97n4="
                    },
                    {
                      "hostname": "gb46-wireguard",
                      "ipv4_addr_in": "146.70.133.66",
                      "ipv6_addr_in": "2001:ac8:8b:2c::a46f",
                      "public_key": "2bciRobW0TPtjrZ2teilr+7PjyiBMUGfixvAKOE52Xo="
                    },
                    {
                      "hostname": "gb-mnc-wg-001",
                      "ipv4_addr_in": "146.70.133.98",
                      "ipv6_addr_in": "2001:ac8:8b:2d::a47f",
                      "public_key": "Q2khJLbTSFxmppPGHgq2HdxMQx7CczPZCgVpYZMoNnM="
                    }
                  ]
                }
              ]
            },
            {
              "name": "USA",
              "code": "us",
              "cities": [
                {
                  "name": "New York, NY",
                  "code": "nyc",
                  "relays": [
                    {
                      "hostname": "us97-wireguard",
                      "ipv4_addr_in": "86.106.143.210",
                      "ipv6_addr_in": "2a0d:5600:24:a94::a97f",
                      "public_key": "5fzEFqyRqc6qa1QPngIBK1gmWc0ex1Bpot/f6RqZPmc="
                    },
                    {
                      "hostname": "us98-wireguard",
                      "ipv4_addr_in": "86.106.143.223",
                      "ipv6_addr_in": "2a0d:5600:24:a95::a98f",
                      "public_key": "bo50ppMvVlNG4S6zqgd/J5l1Ce7Og89u+wR10OvJrQ4="
                    },
                    {
                      "hostname": "us99-wireguard",
                      "ipv4_addr_in": "86.106.143.236",
                      "ipv6_addr_in": "2a0d:5600:24:a96::a99f",
                      "public_key": "EPLh6pVel06dND8cE4Prix9GP4hGLYNhQhn5mSN2yzM="
                    }
                  ]
                },
                {
                  "name": "Seattle, WA",
                  "code": "sea",
                  "relays": [
                    {
                      "hostname": "us274-wireguard",
                      "ipv4_addr_in": "138.199.43.78",
                      "ipv6_addr_in": "2a02:6ea0:d80b:2::b74f",
                      "public_key": "ujasJmDuU0t4y6JmBLrdDxakKuaHvPRupRDfyywSWyw="
                    },
                    {
                      "hostname": "us-sea-wg-001",
                      "ipv4_addr_in": "138.199.43.91",
                      "ipv6_addr_in": "2a02:6ea0:d80b:3::b75f",
                      "public_key": "bZQF7VRDRK/JUJ8L6EFzF/zRw2tsqMRk6FesGtTgsC0="
                    },
                    {
                      "hostname": "us-sea-wg-003",
                      "ipv4_addr_in": "138.199.43.65",
                      "ipv6_addr_in": "2a02:6ea0:d80b:1::b73f",
                      "public_key": "4ke8ZSsroiI6Sp23OBbMAU6yQmdF3xU2N8CyzQXE/Qw="
                    }
                  ]
                }
              ]
            }
          ]
        },
        "output": "146.70.133.98,Q2khJLbTSFxmppPGHgq2HdxMQx7CczPZCgVpYZMoNnM="
      }
    ],
    "identifier": 73913094
  },
  {
    "context": [
      "This is the data I have:",
      "And what I want is a flattened list of `repo:tag` for each of these entries",
      "\"bar/foo/bat:0.0.4-22.09\"",
      "\"thing/foo/baz:0.0.2-22.09\"",
      "\"thing/foo/baz:0.0.3-22.09\"",
      ".[] | .repo + \":\" + .tags[]",
      "Output:",
      "\"bar/foo/bat:0.0.4-22.09\"",
      "\"thing/foo/baz:0.0.2-22.09\"",
      "\"thing/foo/baz:0.0.3-22.09\""
    ],
    "utterance": "For each object, return all combinations of the repo field and each tag, formatted as repo:tag",
    "expressions": [
      ".[] | .repo + \":\" + .tags[]"
    ],
    "data": [
      {
        "input": [
          {
            "repo": "bar/foo/bat",
            "tags": [
              "0.0.4-22.09"
            ]
          },
          {
            "repo": "thing/foo/baz",
            "tags": [
              "0.0.2-22.09",
              "0.0.3-22.09"
            ]
          }
        ],
        "output": [
          "bar/foo/bat:0.0.4-22.09",
          "thing/foo/baz:0.0.2-22.09",
          "thing/foo/baz:0.0.3-22.09"
        ]
      }
    ],
    "identifier": 74047703
  },
  {
    "context": [
      "required output is below, please support. \r\n```\r\nId,paymentId,motthamAmount,curreny\r\n11390,LSDLSLS-LSLSLSLs-KGOGK,331,INR\r\n```",
      "cat test.json  | jq -r '.counts.counts[]._source.payload.ID, .counts.counts[]._source.payload.paymentId, .counts.counts[]._source.payload.dabbulluInfo.motthamAmount, .counts.counts[]._source.payload.dabbulluInfo.currency'",
      "jq -rn '\n([ \"Id\", \"paymentId\", \"motthamAmount\", \"currency\" ] | @csv),\n(inputs | .counts.counts[] | [\n  ._source.payload.ID, \n  ._source.payload.paymentId, \n  ._source.payload.dabbulluInfo.motthamAmount, \n  ._source.payload.dabbulluInfo.currency\n] | @csv)\n' <test.json",
      "jq -r '\n  [\"Id\", \"paymentId\", \"motthamAmount\", \"curreny\"], (\n    .counts.counts[]._source.payload\n    | [.ID, .paymentId, (.dabbulluInfo | .motthamAmount, .currency)]\n  ) | @csv\n'",
      "\"Id\",\"paymentId\",\"motthamAmount\",\"curreny\"\n\"11390\",\"LSDLSLS-LSLSLSLs-KGOGK\",\"331\",\"INR\""
    ],
    "utterance": "Output a CSV with the columns Id, paymentId, motthamAmount, and currency by extracting these properties from the nested payload for each entry in counts.counts",
    "expressions": [
      "jq -rn '([ \"Id\", \"paymentId\", \"motthamAmount\", \"currency\" ] | @csv),(inputs | .counts.counts[] | [._source.payload.ID, ._source.payload.paymentId, ._source.payload.dabbulluInfo.motthamAmount, ._source.payload.dabbulluInfo.currency] | @csv)' <test.json",
      "jq -r '[\"Id\", \"paymentId\", \"motthamAmount\", \"curreny\"], (.counts.counts[]._source.payload | [.ID, .paymentId, (.dabbulluInfo | .motthamAmount, .currency)]) | @csv'"
    ],
    "data": [
      {
        "input": {
          "took": 43,
          "timed_out": false,
          "cardss": {
            "values": 0,
            "faileds": 0
          },
          "counts": {
            "total": 200,
            "max_hint": 1.0000004,
            "counts": [
              {
                "_index": "test_90.008.",
                "_type": "fluentdd",
                "_id": "SLSLSLSLSLLSdfsdhjdshfdshfdshfkjdsfdsfsfdsf",
                "_score": 1.0000004,
                "_source": {
                  "payload": {
                    "ID": "11390",
                    "Key": "SKSKDISKSK",
                    "paymentId": "LSDLSLS-LSLSLSLs-KGOGK",
                    "bunkoinfo": {
                      "janaluID": "918282827",
                      "ipAddress": "0.0.0.0",
                      "chethiid": "fkfkfkfkfkfkfkfkfkkf"
                    },
                    "dabbulluInfo": {
                      "checkType": "mundhucheck",
                      "currency": "INR",
                      "method": "paper",
                      "motthamAmount": "331",
                      "cards": {
                        "cardsToken": "2021000",
                        "upicodes": "331",
                        "cardchettha": "6739837",
                        "digitcardss": "0000",
                        "kaliDate": "00000"
                      }
                    },
                    "PackOrdetls": [
                      {
                        "items": [
                          {
                            "itemName": "00",
                            "quantity": "0",
                            "price": "331"
                          }
                        ]
                      }
                    ],
                    "dtdcid": "kskdkskdsjsjsjdososlsksj"
                  }
                }
              }
            ]
          }
        },
        "output": [
          "Id,paymentId,motthamAmount,curreny",
          "11390,LSDLSLS-LSLSLSLs-KGOGK,331,INR"
        ]
      }
    ],
    "identifier": 74028696
  },
  {
    "context": [
      "I want to iterate through each object in the JSON array to extract and store the `first_name` and `last_name` values. How can I go about properly doing this ?",
      "To extract multiple fields, you need to wrap them in quotes within the filter.",
      ".[] | \"\\(.first_name) \\(.last_name)\"",
      "Output",
      "John Doe",
      "bat man"
    ],
    "utterance": "Extract first_name and last_name values for each object, outputting them as full names.",
    "expressions": [
      ".[] | \"\\(.first_name) \\(.last_name)\""
    ],
    "data": [
      {
        "input": [
          {
            "first_name": "John",
            "last_name": "Doe"
          },
          {
            "first_name": "bat",
            "last_name": "man"
          }
        ],
        "output": [
          "John Doe",
          "bat man"
        ]
      }
    ],
    "identifier": 74048192
  },
  {
    "context": [
      "Wanted to transform it to a simple JSON which has city if relation's primary is true and relation address type is project. Wanted to populate it as empty string as \"\" in case source is not having a relation address type of project.",
      "Expected output if address type \"project\" is not available in source JSON -  This is not working as expected as it's blanking out whole JSON if \"project\" type address is not available in source.",
      "You can use the [alternative operator](https://stedolan.github.io/jq/manual/#Alternativeoperator%3A%2F%2F) `//` to provide a default value:",
      "{\n  miscellenous,\n  \"city\": (\n    (.relations[] | select(.primary) | .address[] | select(.type == \"project\") | .city) // \"\"\n  )\n}"
    ],
    "utterance": "Extract the city where a relation's primary is true and the related address type is project; if not found, return an empty string for city.",
    "expressions": [
      "{ miscellenous, \"city\": (.relations[] | select(.primary) | .address[] | select(.type == \"project\") | .city) // \"\" }"
    ],
    "data": [
      {
        "input": {
          "miscellenous": "apple",
          "relations": [
            {
              "primary": false,
              "rel": 123,
              "address": [
                {
                  "type": "project",
                  "city": "xyz"
                },
                {
                  "type": "mailing",
                  "city": "abc"
                }
              ]
            },
            {
              "primary": true,
              "rel": 456,
              "address": [
                {
                  "type": "project",
                  "city": "xyz"
                },
                {
                  "type": "mailing",
                  "city": "abc"
                }
              ]
            }
          ]
        },
        "output": {
          "miscellenous": "apple",
          "city": "xyz"
        }
      },
      {
        "input": {
          "miscellenous": "apple",
          "relations": [
            {
              "primary": false,
              "rel": 123,
              "address": [
                {
                  "type": "other",
                  "city": "xyz"
                },
                {
                  "type": "mailing",
                  "city": "abc"
                }
              ]
            },
            {
              "primary": true,
              "rel": 456,
              "address": [
                {
                  "type": "mailing",
                  "city": "abc"
                }
              ]
            }
          ]
        },
        "output": {
          "miscellenous": "apple",
          "city": ""
        }
      }
    ],
    "identifier": 74053418
  },
  {
    "context": [
      "I want to put all the filenames of text files into a specific JSON format like this:",
      "So the resulting JSON I wanted should be like this:",
      "tree \u2026 | jq --arg ext '.txt' '\n  {\"\": (first.contents | map(\n    select(.type == \"file\") | {title: \"\", file: .name | rtrimstr($ext)}\n  ))}\n'",
      "{ shopt -s nullglob; set -- *.txt; printf '%s\\0' \"$@\"; } | jq -Rn '\n  {\"\": [ input\n         | split(\"\\u0000\")[]\n         | select(. != \"\")\n         | {\"title\": \"\",\n            \"file\": . | rtrimstr(\".txt\")\n           }\n       ]\n  }\n'",
      "find . -maxdepth 1 -type f -name '*.txt' -printf '%T@ %P\\0' |\n  sort -zn |\n  sed -z -re 's/^[[:digit:].]+ //g' |\n  jq -Rn '",
      "jq  -n --args '{\"\": [ $ARGS.positional[] | rtrimstr(\".txt\") | { title: \"\", file: . } ] }' *.txt"
    ],
    "utterance": "List all filenames ending with .txt in the current directory, remove the .txt extension, sort them by modification time, and output them as objects with empty 'title' and their filename (without extension) as 'file', in a single-key object with an empty string key.",
    "expressions": [
      "tree \u2026 | jq --arg ext '.txt' '{\"\": (first.contents | map(select(.type == \"file\") | {title: \"\", file: .name | rtrimstr($ext)}))}'",
      "{ shopt -s nullglob; set -- *.txt; printf '%s\\0' \"$@\"; } | jq -Rn '{\"\": [ input | split(\"\\u0000\")[] | select(. != \"\") | {\"title\": \"\", \"file\": . | rtrimstr(\".txt\") } ]}'",
      "find . -maxdepth 1 -type f -name '*.txt' -printf '%T@ %P\\0' |\n  sort -zn |\n  sed -z -re 's/^[[:digit:].]+ //g' |\n  jq -Rn '{\"\": [ input | split(\"\\u0000\")[] | select(. != \"\") | {\"title\": \"\", \"file\": . | rtrimstr(\".txt\") } ]}'",
      "jq  -n --args '{\"\": [ $ARGS.positional[] | rtrimstr(\".txt\") | { title: \"\", file: . } ] }' *.txt"
    ],
    "data": [
      {
        "input": [
          "1.txt",
          "2.txt",
          "3.txt"
        ],
        "output": {
          "": [
            {
              "title": "",
              "file": "3"
            },
            {
              "title": "",
              "file": "2"
            },
            {
              "title": "",
              "file": "1"
            }
          ]
        }
      }
    ],
    "identifier": 74035356
  },
  {
    "context": [
      "I need to get all Distinct \"Node\" from an array of data objects only if in the object the \"ServiceTags\" has the String element \"orchestrator\".",
      "the expected result would be an array that contains the values \"xyz\" and \"teb\" because there is a \"orchestrator\" as part of \"ServiceTags\" property.",
      "map(select(.ServiceTags | index(\"orchestrator\")).Node)"
    ],
    "utterance": "Get all Node values from objects whose ServiceTags contains the string 'orchestrator'.",
    "expressions": [
      "map(select(.ServiceTags | index(\"orchestrator\")).Node)"
    ],
    "data": [
      {
        "input": [
          {
            "Node": "abc",
            "ServiceTags": [],
            "Type": "",
            "Definition": {
              "Interval": "0s",
              "Timeout": "0s"
            },
            "CreateIndex": 11241543,
            "ModifyIndex": 11241543
          },
          {
            "Node": "xyz",
            "ServiceTags": [
              "rules",
              "rhdm_es",
              "rhdm",
              "orchestrator"
            ],
            "Type": "http",
            "Definition": {
              "Interval": "0s",
              "Timeout": "0s"
            },
            "CreateIndex": 12907642,
            "ModifyIndex": 12907659
          },
          {
            "Node": "teb",
            "ServiceTags": [
              "rules",
              "orchestrator"
            ],
            "Type": "http",
            "Definition": {
              "Interval": "0s",
              "Timeout": "0s"
            },
            "CreateIndex": 12907642,
            "ModifyIndex": 12907659
          },
          {
            "Node": "iry",
            "ServiceTags": [
              "rules"
            ],
            "Type": "http",
            "Definition": {
              "Interval": "0s",
              "Timeout": "0s"
            },
            "CreateIndex": 12907642,
            "ModifyIndex": 12907659
          }
        ],
        "output": [
          "xyz",
          "teb"
        ]
      }
    ],
    "identifier": 74057674
  },
  {
    "context": [
      "I need to get the \"ubuntu\" node content by searching it with \"18.04\", without knowing the \"ubuntu\" node key name.",
      "So if i search the children node named \"7.4\", it should identify its parent as \"rhel\" and returns it.",
      "Basically, with an os version, i should get the os name, but i have no way of knowing the os name beforehand.",
      "os | to_entries[] | select(.value | has(\"18.04\")).key\n// \"ubuntu\"\n\n.os | to_entries[] | select(.value | has(\"7.6\")).key\n// \"rhel\""
    ],
    "utterance": "Find the top-level OS key whose child contains a specified version number, such as returning 'ubuntu' for '18.04' or 'rhel' for '7.4'.",
    "expressions": [
      ".os | to_entries[] | select(.value | has(\"18.04\")).key",
      ".os | to_entries[] | select(.value | has(\"7.4\")).key"
    ],
    "data": [
      {
        "input": {
          "os": {
            "ubuntu": {
              "16.04": {
                "codename": "xenial",
                "bootstrap": "preseed",
                "guest_type": "ubuntu64Guest",
                "iso_name": "ubuntu-16.04.7-server-amd64.iso",
                "iso_checksum": "9bb30a2ea6466b0c02aacfa96f6e3516"
              },
              "18.04": {
                "codename": "bionic",
                "bootstrap": "preseed",
                "guest_type": "ubuntu64Guest",
                "iso_name": "ubuntu-18.04.2-server-amd64.iso",
                "iso_checksum": "34416ff83179728d54583bf3f18d42d2",
                "arm": {
                  "iso_name": "ubuntu-18.04.5-server-arm64.iso",
                  "iso_checksum": "5056eaf87425b550376e6733b05de6e9"
                }
              }
            },
            "rhel": {
              "7.4": {
                "codename": "maipo",
                "bootstrap": "kickstart",
                "guest_type": "rhel7_64Guest",
                "iso_name": "rhel-server-7.4-x86_64-boot.iso",
                "iso_checksum": "94ad0929b79b5d13b33acafc8da8d364"
              },
              "7.6": {
                "codename": "maipo",
                "bootstrap": "kickstart",
                "guest_type": "rhel7_64Guest",
                "iso_name": "rhel-server-7.6-x86_64-boot.iso",
                "iso_checksum": "4a611d2bbfa6912eada91096af14ec84"
              }
            }
          }
        },
        "output": "ubuntu"
      },
      {
        "input": {
          "os": {
            "ubuntu": {
              "16.04": {},
              "18.04": {}
            },
            "rhel": {
              "7.4": {},
              "7.6": {}
            }
          }
        },
        "output": "rhel"
      }
    ],
    "identifier": 74042901
  },
  {
    "context": [
      "I want to get `success` without containing double quote.",
      "Can jq achieve same target with its some argument without piping to sed?",
      "Just use jq's command-line option `-r`."
    ],
    "utterance": "Return the value of the message property without double quotes around the output.",
    "expressions": [
      "jq -r .message"
    ],
    "data": [
      {
        "input": {
          "message": "success",
          "timestamp": 1665708640,
          "iss_position": {
            "longitude": "-114.2621",
            "latitude": "8.5148"
          }
        },
        "output": "success"
      }
    ],
    "identifier": 74063270
  },
  {
    "context": [
      "To single-line output",
      "jq --compact-output '' <<< \"$test\"",
      "$ jq --compact-output '' <<< \"$test\"\n{\"type\":\"service_account\",\"project_id\":\"projectid234\",\"private_key_id\":\"aasdadsxzce5\",\"private_key\":\"-----BEGIN PRIVATE KEY-----\\nMIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQCiWjA5+xF6gsGC\\nOknIL9DOCQpV2LRXYPEKl5+mXuN45vwqh6QvG4lw/Hi7EJhtAn+FQy7+yOQYrw3l\\nQ2CpxDotT+PT2OuQ6LVbc/F+SblPlrK3B+8aEMo57PZ+gnwMcQ7+ofPnzC635uUP\\npOG0idMTK\\n-----END PRIVATE KEY-----\\n\",\"client_email\":\"clinetmail@asdasd3435.iam.gserviceaccount.com\",\"client_id\":\"1234242342341\",\"auth_uri\":\"https://accounts.google.com/o/oauth2/auth\",\"token_uri\":\"https://oauth2.googleapis.com/token\",\"auth_provider_x509_cert_url\":\"https://www.googleapis.com/oauth2/v1/certs\",\"client_x509_cert_url\":\"https://www.googleapis.com/robot/v1/metadata/x509/assadjashd.iam.gserviceaccount.com\"}"
    ],
    "utterance": "Convert multi-line to single-line by preserving all data and formatting compactly.",
    "expressions": [
      "jq --compact-output ''"
    ],
    "data": [
      {
        "input": {
          "type": "service_account",
          "project_id": "projectid234",
          "private_key_id": "aasdadsxzce5",
          "private_key": "-----BEGIN PRIVATE KEY-----\\nMIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQCiWjA5+xF6gsGC\\nOknIL9DOCQpV2LRXYPEKl5+mXuN45vwqh6QvG4lw/Hi7EJhtAn+FQy7+yOQYrw3l\\nQ2CpxDotT+PT2OuQ6LVbc/F+SblPlrK3B+8aEMo57PZ+gnwMcQ7+ofPnzC635uUP\\npOG0idMTK\\n-----END PRIVATE KEY-----\\n",
          "client_email": "clinetmail@asdasd3435.iam.gserviceaccount.com",
          "client_id": "1234242342341",
          "auth_uri": "https://accounts.google.com/o/oauth2/auth",
          "token_uri": "https://oauth2.googleapis.com/token",
          "auth_provider_x509_cert_url": "https://www.googleapis.com/oauth2/v1/certs",
          "client_x509_cert_url": "https://www.googleapis.com/robot/v1/metadata/x509/assadjashd.iam.gserviceaccount.com"
        },
        "output": "{\"type\":\"service_account\",\"project_id\":\"projectid234\",\"private_key_id\":\"aasdadsxzce5\",\"private_key\":\"-----BEGIN PRIVATE KEY-----\\nMIIEvgIBADANBgkqhkiG9w0BAQEFAASCBKgwggSkAgEAAoIBAQCiWjA5+xF6gsGC\\nOknIL9DOCQpV2LRXYPEKl5+mXuN45vwqh6QvG4lw/Hi7EJhtAn+FQy7+yOQYrw3l\\nQ2CpxDotT+PT2OuQ6LVbc/F+SblPlrK3B+8aEMo57PZ+gnwMcQ7+ofPnzC635uUP\\npOG0idMTK\\n-----END PRIVATE KEY-----\\n\",\"client_email\":\"clinetmail@asdasd3435.iam.gserviceaccount.com\",\"client_id\":\"1234242342341\",\"auth_uri\":\"https://accounts.google.com/o/oauth2/auth\",\"token_uri\":\"https://oauth2.googleapis.com/token\",\"auth_provider_x509_cert_url\":\"https://www.googleapis.com/oauth2/v1/certs\",\"client_x509_cert_url\":\"https://www.googleapis.com/robot/v1/metadata/x509/assadjashd.iam.gserviceaccount.com\"}"
      }
    ],
    "identifier": 73989336
  },
  {
    "context": [
      "Now I want to extract All values like (Username , password,..)",
      "After get all extract values add in another json file called (secondfile.json)",
      "Sample Output: extracted values now stored second file.json file in Aurora[] array elements.",
      "Note: Input.json value not fixed , it may be contain 3 json key/value or n number of key/value",
      "If I understand your question correctly, you simply want to embed/wrap the input document in a top level document.",
      "echo '{\"Username\":\"admin\",\"Password\":\"admin\",\"Endpoint\":\"localhost\",\"DatabaseName\":\"example\",\"Port\":\"3306\"}' | jq '{\n  \"Logging\": {\n    \"LogLevel\": {\n      \"Default\": \"Information\",\n      \"Microsoft.AspNetCore\": \"Warning\"\n    }\n  },\n  \"Aurora\": .\n}'",
      "jq --slurpfile tpl template.json '$tpl[0] + {Aurora: with_entries(select(.key | IN($tpl[0].Aurora|keys[])))}' <input.json",
      "jq --slurpfile in input.json '.Aurora |= keys as $keys | $in[0] | with_entries(select(.key | IN($keys[])))' <template.json"
    ],
    "utterance": "Update the 'Aurora' object in an existing file so that its fields are filled with corresponding values from another file, including only those keys present in both.",
    "expressions": [
      "{\n  \"Logging\": {\n    \"LogLevel\": {\n      \"Default\": \"Information\",\n      \"Microsoft.AspNetCore\": \"Warning\"\n    }\n  },\n  \"Aurora\": .\n}",
      "$tpl[0] + {Aurora: with_entries(select(.key | IN($tpl[0].Aurora|keys[])))}",
      ".Aurora |= keys as $keys | $in[0] | with_entries(select(.key | IN($keys[])))"
    ],
    "data": [
      {
        "input": {
          "Username": "admin",
          "Password": "admin",
          "Endpoint": "localhost",
          "DatabaseName": "example",
          "Port": "3306",
          "SomethingElse": "ignore me"
        },
        "output": {
          "Logging": {
            "LogLevel": {
              "Default": "Information",
              "Microsoft.AspNetCore": "Warning"
            }
          },
          "Aurora": {
            "Username": "admin",
            "Password": "admin",
            "Endpoint": "localhost",
            "DatabaseName": "example",
            "Port": "3306"
          }
        }
      },
      {
        "input": {
          "Logging": {
            "LogLevel": {
              "Default": "Information",
              "Microsoft.AspNetCore": "Warning"
            }
          },
          "Aurora": {
            "Username": "",
            "Password": "",
            "Endpoint": "",
            "DatabaseName": "",
            "Port": ""
          }
        },
        "output": {
          "Logging": {
            "LogLevel": {
              "Default": "Information",
              "Microsoft.AspNetCore": "Warning"
            }
          },
          "Aurora": {
            "Username": "admin",
            "Password": "admin",
            "Endpoint": "localhost",
            "DatabaseName": "example",
            "Port": "3306"
          }
        }
      }
    ],
    "identifier": 74053106
  },
  {
    "context": [
      "I want my address to show first before telephone.  How do I do this with jq?",
      "Ultimately, I want address before telephone:",
      "But this would give me instead:",
      "Oops, it was easy as:\r\n```\r\njq \". | {name: .name, info: {address: .info.address, telephone: .info.telephone}}\" sample.json\r\n```",
      "Or just: `.info |= {address,telephone}`"
    ],
    "utterance": "Reorder the fields inside the info object so that address appears before telephone, while preserving the original data.",
    "expressions": [
      ". | {name: .name, info: {address: .info.address, telephone: .info.telephone}}",
      ".info |= {address,telephone}"
    ],
    "data": [
      {
        "input": {
          "name": "john",
          "info": {
            "telephone": "444-5555",
            "address": "1234 Main st"
          }
        },
        "output": {
          "name": "john",
          "info": {
            "address": "1234 Main st",
            "telephone": "444-5555"
          }
        }
      },
      {
        "input": {
          "name": "jane",
          "info": {
            "telephone": "222-3333",
            "address": "1234 Eagle st"
          }
        },
        "output": {
          "name": "jane",
          "info": {
            "address": "1234 Eagle st",
            "telephone": "222-3333"
          }
        }
      }
    ],
    "identifier": 74063595
  },
  {
    "context": [
      "sort_by(.person) # first sort in ascending\n| reverse | sort_by(.city) | reverse # then sort by in descending",
      "More of an idea than a good solution, but you could sort by negative codepoints obtained by using `explode`. At least there&#39;s no `reverse` involved, and only one call to `sort_by` is needed for all criteria.\n~~~sh\nsort_by(.person, (.city | [-explode[]]))\n~~~",
      "`reverse_merge_sort_by(f)` as defined here is a stable reverse merge-sort, where the primary order is determined by f:",
      "def reverse_merge_sort_by(f):\n  if length <= 1 then .\n  else (length/2 |floor) as $len\n  | reverse_merge_by( .[:$len] | reverse_merge_sort_by(f);\n                      .[$len:] | reverse_merge_sort_by(f); f )\n  end;"
    ],
    "utterance": "Sort a list by 'person' ascending and 'city' descending in a single query without using double reverse.",
    "expressions": [
      "sort_by(.person, (.city | [-explode[]]))",
      "def reverse_merge_by($x; $y; f):\n  def m:  # state: [i, j, array]  (i and j being indices into x and y respectively)\n    .[0] as $i | .[1] as $j\n    | if $i == -1 then $y[:$j + 1] + .[2]\n      elif $j == -1 then $x[:$i + 1] + .[2]\n      elif ($x[$i]|f) < ($y[$j]|f)\n      then [$i - 1, $j,     [$x[$i]] + .[2] ] | m\n      else [$i,     $j - 1, [$y[$j]] + .[2] ] | m\n      end\n      ;\n   [($x|length - 1), ($y|length -1), []] | m;\ndef reverse_merge_sort_by(f):\n  if length <= 1 then .\n  else (length/2 |floor) as $len\n  | reverse_merge_by( .[:$len] | reverse_merge_sort_by(f);\n                      .[$len:] | reverse_merge_sort_by(f); f )\n  end;\nreverse_merge_sort_by(.person)",
      "reverse_merge_sort_by((.person, (.city | [-explode[]])))"
    ],
    "identifier": 74058111
  },
  {
    "context": [
      "I have this bit of json:",
      "I'm using jq 1.6 and I'm trying to get this output:\r\n\r\n    [{\r\n      \"id\": \"62466\",\r\n      \"name\": \"Ice B\",\r\n      \"category\": \"Ice\"\r\n    },\r\n    {\r\n      \"id\": \"66642\",\r\n      \"name\": \"Ice A\",\r\n      \"category\": \"Ice\"\r\n    },\r\n    {\r\n      \"id\": \"14105\",\r\n      \"name\": \"Cake 2\",\r\n      \"category\": \"Cakes\"\r\n    },\r\n    {\r\n      \"id\": \"14518\",\r\n      \"name\": \"Cake 1\",\r\n      \"category\": \"Cakes\"\r\n    }]",
      "Because there are some duplicate records, ie: products that have more than one category I need them to be unique. How can i fix this?",
      "This map produces the 4 unique items.\r\n\r\n~~~sh\r\njq 'map(\r\n  (.categories[].products | unique_by(.id)[] | {id, name: .display_name})\r\n  + {category: .name}\r\n)'",
      "Assigning the category name in a variable and then transforming each product with unique id:\r\n\r\n```\r\nmap(\r\n    .name as $category\r\n    | .categories[].products\r\n    | unique_by(.id)\r\n    | .[]\r\n    | { id, name: .display_name, $category }\r\n)\r\n```"
    ],
    "utterance": "Get an array of unique products with their id, display_name as name, and the parent object name as category.",
    "expressions": [
      "map((.categories[].products | unique_by(.id)[] | {id, name: .display_name}) + {category: .name})",
      "map(.name as $category | .categories[].products | unique_by(.id) | .[] | { id, name: .display_name, category: $category })"
    ],
    "data": [
      {
        "input": [
          {
            "id": 123,
            "name": "Ice",
            "categories": [
              {
                "products": [
                  {
                    "id": "66642",
                    "display_name": "Ice A"
                  },
                  {
                    "id": "62466",
                    "display_name": "Ice B"
                  },
                  {
                    "id": "62466",
                    "display_name": "Ice B duplicate"
                  }
                ]
              }
            ]
          },
          {
            "id": 97,
            "name": "Cakes",
            "categories": [
              {
                "products": [
                  {
                    "id": "14518",
                    "display_name": "Cake 1"
                  },
                  {
                    "id": "14105",
                    "display_name": "Cake 2"
                  }
                ]
              }
            ]
          }
        ],
        "output": [
          {
            "id": "62466",
            "name": "Ice B",
            "category": "Ice"
          },
          {
            "id": "66642",
            "name": "Ice A",
            "category": "Ice"
          },
          {
            "id": "14105",
            "name": "Cake 2",
            "category": "Cakes"
          },
          {
            "id": "14518",
            "name": "Cake 1",
            "category": "Cakes"
          }
        ]
      }
    ],
    "identifier": 74048427
  },
  {
    "context": [
      "I has 3 arrays. I would like to replicate the last array to each of the prevoius ones, so it will look like this:",
      "Convert the stream into an array either by using `-n` with `[inputs]`, or by using `-s`, then add the `last` item to all but the last `.[:-1][]`. To filter out the empty object, `select` by comparing it to `{}` or by checking its `length`.",
      "jq -s '(.[:-1][] | select(length > 0)) + last'"
    ],
    "utterance": "Add the brand and cats fields from the last object to each of the previous objects, excluding empty objects.",
    "expressions": [
      "jq -n '[inputs] | (.[:-1][] | select(. != {})) + last'",
      "jq -s '(.[:-1][] | select(length > 0)) + last'"
    ],
    "data": [
      {
        "input": [
          {
            "name": "The 24H Automatic Eye Pencil",
            "url": "/3ina/the-24h-automatic-pencil-waterproof-brow-pencil/p-16132421/",
            "id": "16132421",
            "gender": "W"
          },
          {
            "name": "The 24H Automatic Eye Pencil",
            "url": "/3ina/the-24h-automatic-pencil-waterproof-brow-pencil/p-16104273/",
            "id": "16104273",
            "gender": "W"
          },
          {},
          {
            "brand": "3INA",
            "cats": [
              "Makeup",
              "Eyebrows",
              "Eyebrow Makeup"
            ]
          }
        ],
        "output": [
          {
            "name": "The 24H Automatic Eye Pencil",
            "url": "/3ina/the-24h-automatic-pencil-waterproof-brow-pencil/p-16132421/",
            "id": "16132421",
            "gender": "W",
            "brand": "3INA",
            "cats": [
              "Makeup",
              "Eyebrows",
              "Eyebrow Makeup"
            ]
          },
          {
            "name": "The 24H Automatic Eye Pencil",
            "url": "/3ina/the-24h-automatic-pencil-waterproof-brow-pencil/p-16104273/",
            "id": "16104273",
            "gender": "W",
            "brand": "3INA",
            "cats": [
              "Makeup",
              "Eyebrows",
              "Eyebrow Makeup"
            ]
          }
        ]
      }
    ],
    "identifier": 74074360
  },
  {
    "context": [
      "I have a 100+GB json file and when I try to read it with jq my computer keeps running our of ram. Is there a way to read the file while limiting the memory usage or some other way to read a VERY huge json file?",
      "If your file is huge, but the documents inside the file aren't that big (just many many smaller ones), `jq -n 'inputs'` could get you started:",
      "jq -n 'inputs | keys'",
      "One generic way to determine the structure of a very large file containing a single JSON entity would be to run the following query:",
      "jq -nc --stream -f structural-paths.jq huge.json | sort -u",
      "inputs\n| select(length == 2)\n| .[0]\n| map( if type == \"number\" then 0 else . end )"
    ],
    "utterance": "List the keys of each top-level object in a very large file containing many top-level objects, without loading the entire file into memory.",
    "expressions": [
      "jq -n 'inputs | keys' filename.json"
    ],
    "identifier": 74076187
  },
  {
    "context": [
      "Now, if the name is hello1, then I want to add 18hours to the startdate and create a new key called \"endate\". For hello2, I want to add 24hours to startdate and create \"endate\".",
      "One way:",
      ".data[] |= ( (.name | if test(\"hello1\") then 18 else 24 end) as $add | .enddate = ( .startdate | strptime(\"%F %T\") | .[3] += $add | mktime | strftime(\"%F %T\") ) )",
      "Note: `test` implements a regex match. For a simple string comparison `.name == \"hello1\"` would suffice."
    ],
    "utterance": "For each object, if the name is hello1 add 18 hours to startdate and set enddate, else add 24 hours to startdate and set enddate.",
    "expressions": [
      ".data[] |= ((.name | if test(\"hello1\") then 18 else 24 end) as $add | .enddate = (.startdate | strptime(\"%F %T\") | .[3] += $add | mktime | strftime(\"%F %T\")))"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": 1,
              "startdate": "2022-10-14 12:05:49",
              "name": "hello1",
              "run_status_index": 29
            },
            {
              "id": 2,
              "startdate": "2022-10-14 11:45:36",
              "name": "hello2",
              "run_status_index": 95
            }
          ]
        },
        "output": {
          "data": [
            {
              "id": 1,
              "startdate": "2022-10-14 12:05:49",
              "name": "hello1",
              "run_status_index": 29,
              "enddate": "2022-10-15 06:05:49"
            },
            {
              "id": 2,
              "startdate": "2022-10-14 11:45:36",
              "name": "hello2",
              "run_status_index": 95,
              "enddate": "2022-10-15 11:45:36"
            }
          ]
        }
      }
    ],
    "identifier": 74075292
  },
  {
    "context": [
      "I am trying to use `jq` to filter on the `.data.person` elements and return the first `.data` item with a non-null `person`.",
      "output should be:\r\n\r\n    {'color' : 'blue', 'person' : 'john'}",
      "You can use the `first/1` built-in to perform this,\r\n\r\nfirst(.data[]? | select(.person | length > 0))"
    ],
    "utterance": "Return the first element from the data array where the person field is non-empty.",
    "expressions": [
      "first(.data[]? | select(.person | length > 0))"
    ],
    "data": [
      {
        "input": {
          "document": "test",
          "data": [
            {
              "color": "blue",
              "person": "john"
            },
            {
              "color": "red",
              "person": []
            },
            {
              "color": "purple",
              "person": "alice"
            }
          ]
        },
        "output": {
          "color": "blue",
          "person": "john"
        }
      }
    ],
    "identifier": 74120371
  },
  {
    "context": [
      "But when my key is mutable, how should I loop? For example, the script I execute is\n\n    test.sh k1=v1 k2=v2 k3=v3",
      "The above two methods have not achieved the goal, do you have a good way to deal with it? My desired output is\n\n   { \"k1\": \"v1\" , \"k2\": \"v2\" ,\"K3\": \"V3\" }",
      "If your values can contain `=` themselves, you have to join all but the first value of the array:\n\n```\njq -n '$ARGS.positional\n| map(./\"=\" | {key:first,value:.[1:]|join(\"=\")})\n| from_entries' --args \"$@\"\n```",
      "jq -n '$ARGS.positional | map(./\"=\" | {key:first,value:last}) | from_entries' --args \"$@\"",
      "jq -n --args '\n    $ARGS.positional as $a\n    | reduce range(0; $a | length; 2) as $i ({}; .[$a[$i]] = $a[$i + 1])\n' \"${args[@]}\""
    ],
    "utterance": "Combine key=value arguments from shell script parameters into a single object where each key and value are set according to the pairs, handling any number of arguments.",
    "expressions": [
      "jq -n '$ARGS.positional | map(./\"=\" | {key:first,value:last}) | from_entries' --args \"$@\"",
      "jq -n '\n    $ARGS.positional as $a\n    | reduce range(0; $a | length; 2) as $i ({}; .[$a[$i]] = $a[$i + 1])\n' \"${args[@]}\"",
      "jq -n '$ARGS.positional\n| map(./\"=\" | {key:first,value:.[1:]|join(\"=\")})\n| from_entries' --args \"$@\""
    ],
    "data": [
      {
        "input": [
          "k1=v1",
          "k2=v2",
          "k3=v3"
        ],
        "output": {
          "k1": "v1",
          "k2": "v2",
          "k3": "v3"
        }
      },
      {
        "input": [
          "foo=bar=baz",
          "x=y"
        ],
        "output": {
          "foo": "bar=baz",
          "x": "y"
        }
      }
    ],
    "identifier": 74095381
  },
  {
    "context": [
      "by running `jq -r '.meta | .title, .description' ./project.json`, which gives me the expected result:",
      "Now I need to assign the content to a variable in my bash script:",
      "But this is not working because of the spaces. Also later I have to escape all spaces, which I would do with:",
      "Taking advantage of jq's support for generating `sh`-compatible eval-safe escaping, we can also do the following, which _does_ correctly handle strings with newlines:",
      "eval \"$(jq -r '\n  .meta | \"description=\\(.description|@sh); title=\\(.title|@sh)\"\n' ./project.json)\""
    ],
    "utterance": "Assign title and description fields containing spaces from the meta object to shell variables and escape spaces so they are preserved and shell-safe.",
    "expressions": [
      ".meta | \"description=\\(.description|@sh); title=\\(.title|@sh)\""
    ],
    "data": [
      {
        "input": {
          "meta": {
            "title": "This is a title",
            "description": "Just a description"
          }
        },
        "output": "description='Just a description'; title='This is a title'"
      }
    ],
    "identifier": 74115373
  },
  {
    "context": [
      "But some important detailed information I missed:",
      "The text files include one **title-line** which contains the **title-value** that will be extracted into the *abc.json*, i.e., `## hello` means that \"hello\" need to be put into `title` field in *abc.json*. The **title-line**, could be anyline in the file, looks like `## <title-value>`. The **title-identifier** `##` is fixed and sperated with **title-value** by one single whitespace which is the first whitespace in the **title-line**.",
      "Before updating, the *abc.json* looks like this:",
      "{\n  \"\": [\n    {\n      \"title\": \"\",\n      \"file\": \"The filename of text file may contain space\"\n    },\n    {\n      \"title\": \"\",\n      \"file\": \"The text file contain one title line and more content\"\n    },\n    {\n      \"title\": \"\",\n      \"file\": \"The title identifier in the text file is fixed\"\n    }\n  ]\n}",
      "After updating, the *abc.json* should be like this:",
      "{\n  \"\": [\n    {\n      \"title\": \"I'm fine, thank you.\",\n      \"file\": \"The filename of text file may contain space\"\n    },\n    {\n      \"title\": \"hello world\",\n      \"file\": \"The text file contain one title line and more content\"\n    },\n    {\n      \"title\": \"How are you?\",\n      \"file\": \"The title identifier in the text file is fixed\"\n    }\n  ]\n}",
      "Use `input_filename` to get the input files' names, read their raw content with the `-R` flag set, and use `select` to find the right item to update; all in one go:"
    ],
    "utterance": "Update each object's title field in the array so its value is taken from the first line in the corresponding text file matching pattern '^## ', using the object's file field as the matching key for the filename (without .txt extension); support filenames with spaces.",
    "expressions": [
      "jq -Rn --argfile base abc.json '\n  reduce (inputs | select(test(\"^## \")) | sub(\"^## \";\"\") | ltrimstr(\" \") as $title | (input_filename | gsub(\"\\\\.txt$\"; \"\")) as $file | [$title, $file]) as $entries ($base;\n    reduce $entries[] as [$title, $file] (.;\n      (.[\"\"[] | select(.file == $file)).title = $title\n    )\n  )\n' *.txt"
    ],
    "data": [
      {
        "input": {
          "": [
            {
              "title": "",
              "file": "The filename of text file may contain space"
            },
            {
              "title": "",
              "file": "The text file contain one title line and more content"
            },
            {
              "title": "",
              "file": "The title identifier in the text file is fixed"
            }
          ]
        },
        "output": {
          "": [
            {
              "title": "I'm fine, thank you.",
              "file": "The filename of text file may contain space"
            },
            {
              "title": "hello world",
              "file": "The text file contain one title line and more content"
            },
            {
              "title": "How are you?",
              "file": "The title identifier in the text file is fixed"
            }
          ]
        }
      }
    ],
    "identifier": 74055447
  },
  {
    "context": [
      "\"I need to split values from key \\\"Text\\\" on base space \\\" \\\" and join to one line.\"",
      "\"if key Text has S10 is show only S1.\"",
      "\"I would like to have this result",
      "5SE32DFVLG002;500001;95001;S1-W1R;TEST;0050SWSW",
      "5SE32DFVLG002;500001;95004;S1-W10R;TEST;0050SWSW\"",
      "\"Modify the part involving generation of `.Text` to something simpler using `split()` method in `jq` that can be used to split on a single white-space.\"",
      "\"( .Text | split(\\\" \\\" ) | .[0] + \\\"-\\\" + .[1] ) + .StringValue[0:1]\""
    ],
    "utterance": "Extract the first and second space-separated items from the 'Text' value, join them with a hyphen, append the first character of 'StringValue', and output all fields in a specific format for entries where ClassificationNo equals 500001 and StringValue is not empty.",
    "expressions": [
      ".[] | [ select( .ClassificationNo ==\"500001\" and .StringValue != \"\" ) | { PartNumber, ClassificationNo, StringValue, Field, Text } ] | sort_by(.Field) | map( .PartNumber, .ClassificationNo, .Field[3:5], ( .Text | split(\" \") | .[0] + \"-\" + .[1] ) + .StringValue[0:1], \"Test\", .StringValue[1:10]) | join(\";\")"
    ],
    "data": [
      {
        "input": [
          {
            "PartNumber": "5SE32DFVLG002",
            "ClassificationNo": "500001",
            "StringValue": "R0050SWSW",
            "Field": "95001",
            "Text": "S1 W1  cr.sec+colour"
          },
          {
            "PartNumber": "5SE32DFVLG002",
            "ClassificationNo": "500001",
            "StringValue": "R0050SWSW",
            "Field": "95004",
            "Text": "S1 W10 cr.sec+colour"
          }
        ],
        "output": [
          "5SE32DFVLG002;500001;95001;S1-W1R;TEST;0050SWSW",
          "5SE32DFVLG002;500001;95004;S1-W10R;TEST;0050SWSW"
        ]
      }
    ],
    "identifier": 74106533
  },
  {
    "context": [
      "The updated input json:",
      "{\n    \"A\": {\n      \"A1\": {\n        \"foo\": {\n          \"_\": \"_\"\n        }\n      },\n      \"A2\": {\n        \"_\": \"_\"\n      }\n    },\n    \"B\": {\n      \"B1\": {}\n    }\n}",
      "The expected output should be:",
      "{\n    \"A\": {\n      \"A1\": {\n        \"foo\": {\n          \"_\": \"_\"\n        }\n      }\n    }\n}",
      "fromstream(tostream | select(length==1 or (.[0]|index(\"foo\"))))",
      "paths as $p\n| select($p[-1]==\"foo\")\n| getpath($p) as $v\n| {} | setpath($p;$v)",
      ". as $in\n| reduce (paths | select(.[-1] == \"foo\")) as $p (\n    null;\n    setpath($p; $in | getpath($p))\n)"
    ],
    "utterance": "Extract all objects whose key is exactly \"foo\", preserving their containing structure.",
    "expressions": [
      "fromstream(tostream | select(length==1 or (.[0]|index(\"foo\"))))",
      "paths as $p | select($p[-1]==\"foo\") | getpath($p) as $v | {} | setpath($p;$v)",
      ". as $in | reduce (paths | select(.[-1] == \"foo\")) as $p (null; setpath($p; $in | getpath($p)))"
    ],
    "data": [
      {
        "input": {
          "A": {
            "A1": {
              "foo": {
                "_": "_"
              }
            },
            "A2": {
              "_": "_"
            }
          },
          "B": {
            "B1": {}
          }
        },
        "output": {
          "A": {
            "A1": {
              "foo": {
                "_": "_"
              }
            }
          }
        }
      }
    ],
    "identifier": 74136190
  },
  {
    "context": [
      "The activities object is a string and I have successfully been able to parse it out with the following in jq.",
      "The following command allows me to parse out the string object but I haven't quite figured out how to get it back into the original array.",
      "Preferred Output",
      "And to merge the activities sub-object into its parent object, while deleting the old property:",
      "map(. + (.activities | fromjson) | del(.activities))",
      "Something like this should be enough:",
      "map(del(.activities) + (.activities | fromjson))"
    ],
    "utterance": "Merge all key-value pairs from the parsed activities field into each object and remove the original activities property.",
    "expressions": [
      "map(. + (.activities | fromjson) | del(.activities))",
      "map(del(.activities) + (.activities | fromjson))"
    ],
    "data": [
      {
        "input": [
          {
            "id": 101,
            "created_at": "1987-10-12 03:20:22.903",
            "updated_at": "1987-10-12 01:20:36.019",
            "activities": "{\"hero\": \"batman\", \"weapon\": \"sword\", \"ts\": null, \"remote\": \"1\",\"game\": \"joker\", \"image\": \"bold\"}"
          },
          {
            "id": 102,
            "created_at": "2022-10-12 11:20:22.903724",
            "updated_at": "2022-10-12 11:20:36.019043",
            "activities": "{\"hero\": \"superman\", \"weapon\": \"cape\", \"ts\": null, \"remote\": \"2\",\"game\": \"batman\", \"image\": \"kind\"}"
          }
        ],
        "output": [
          {
            "id": 101,
            "created_at": "1987-10-12 03:20:22.903",
            "updated_at": "1987-10-12 01:20:36.019",
            "hero": "batman",
            "weapon": "sword",
            "ts": null,
            "remote": "1",
            "game": "joker",
            "image": "bold"
          },
          {
            "id": 102,
            "created_at": "2022-10-12 11:20:22.903724",
            "updated_at": "2022-10-12 11:20:36.019043",
            "hero": "superman",
            "weapon": "cape",
            "ts": null,
            "remote": "2",
            "game": "batman",
            "image": "kind"
          }
        ]
      }
    ],
    "identifier": 74064774
  },
  {
    "context": [
      "I only need variables from the field `\"data\"`.",
      "eval $(jq -r '.data | to_entries | map(\"export \" + .key + \"='\"'\"'\" + .value + \"'\"'\"'\" )[]' \"$FILE\")",
      "KEYS=$(jq -r '.data | keys[]' <<< \"$RESPONSE\")",
      "VALUE=$(jq -r --arg key \"$KEY\" '.data | .[$key]' <<< \"$RESPONSE\")"
    ],
    "utterance": "Extract all key-value pairs from the 'data' object so each key and its value can be set as a shell variable.",
    "expressions": [
      ".data | to_entries | map(\"export \" + .key + \"='\" + .value + \"'\")[]",
      ".data | keys[]",
      ".data | .[$key]"
    ],
    "data": [
      {
        "input": {
          "data": {
            "warnings": "1",
            "auth": "no"
          }
        },
        "output": [
          "export warnings='1'",
          "export auth='no'"
        ]
      }
    ],
    "identifier": 74137627
  },
  {
    "context": [
      "os.system('aws ce get-cost-and-usage --profile dev --time-period Start=2022-10-01,End=2022-10-31 + 1 month  - 1 second\" -I) --granularity MONTHLY --metrics USAGE_QUANTITY BLENDED_COST  --group-by Type=DIMENSION,Key=SERVICE | /bin/jq  '[ .ResultsByTime[].Groups[] | select(.Metrics.BlendedCost.Amount > \"0\") | { (.Keys[0]): .Metrics.BlendedCost } ] | sort_by(.Amount)| add' > /tmp/cost.json')",
      "os.system('''aws ce get-cost-and-usage --profile dev --time-period Start=$(date \"+%Y-%m-01\"),End=$(date --date=\"$(date +'%Y-%m-01') + 1 month  - 1 second\" -I) --granularity MONTHLY --metrics USAGE_QUANTITY BLENDED_COST  --group-by Type=DIMENSION,Key=SERVICE | jq -r '[ .ResultsByTime[].Groups[] | select(.Metrics.BlendedCost.Amount > \"0\") | { (.Keys[0]): .Metrics.BlendedCost } ] | sort_by(.Amount)| add'  > /tmp/cost.json''')"
    ],
    "utterance": "Filter and transform cost and usage results to select groups where BlendedCost.Amount > 0, mapping the first key to its BlendedCost, sorting by Amount, and combining into a single object.",
    "expressions": [
      "[ .ResultsByTime[].Groups[] | select(.Metrics.BlendedCost.Amount > \"0\") | { (.Keys[0]): .Metrics.BlendedCost } ] | sort_by(.Amount)| add"
    ],
    "identifier": 74139484
  },
  {
    "context": [
      "I'd like to find a way to keep the exact same input format.",
      "jq '.devices[] | select(.label == \"label2\").percent = 50' file.json",
      "But here's the ouput:\n...\nThe devices object (?) is not there anymore.",
      "Make the traversal and filtering all part of the assignment's LHS using parentheses:\n~~~sh\njq '(.devices[] | select(.label == \"label2\").percent) = 50' file.json\n~~~",
      "Alternatively, ... `|=` to a `map` of the whole `.devices` array:\n~~~sh\njq '.devices |= map(select(.label == \"label2\").percent = 50)' file.json\n~~~",
      "Output:\n~~~json\n{\n  \"devices\": [\n    {\n      \"label\": \"label1\",\n      \"percent\": 10\n    },\n    {\n      \"label\": \"label2\",\n      \"percent\": 50\n    }\n  ]\n}\n~~~"
    ],
    "utterance": "Update the 'percent' value to 50 for the object where 'label' equals 'label2', keeping the overall structure unchanged.",
    "expressions": [
      "(.devices[] | select(.label == \"label2\").percent) = 50",
      ".devices |= map(select(.label == \"label2\").percent = 50)"
    ],
    "data": [
      {
        "input": {
          "devices": [
            {
              "label": "label1",
              "percent": 10
            },
            {
              "label": "label2",
              "percent": 20
            }
          ]
        },
        "output": {
          "devices": [
            {
              "label": "label1",
              "percent": 10
            },
            {
              "label": "label2",
              "percent": 50
            }
          ]
        }
      }
    ],
    "identifier": 74142354
  },
  {
    "context": [
      "I use jq 1.6 and I try to round the number to two decimal places. How can I do it?",
      "echo 20.152 | jq -c 'round'",
      "My output:\n\n    20",
      "Expected output:\n\n    20.15",
      "You can multiply by a power of ten, round, then divide by the same power of ten. Use `100` for two decimal digits. Ignoring floating point inaccuracies, this should give you your expected number.",
      "jq '.*100|round/100'",
      "If you need it regularly, you can define a function and use it:",
      "def round(precision):.*pow(10;precision)|round/pow(10;precision);",
      "$ echo 20.152 | jq 'round(2)'",
      "20.15"
    ],
    "utterance": "Round a number to two decimal places, so that 20.152 becomes 20.15.",
    "expressions": [
      ".*100|round/100",
      "def round(precision):.*pow(10;precision)|round/pow(10;precision); round(2)"
    ],
    "data": [
      {
        "input": 20.152,
        "output": 20.15
      }
    ],
    "identifier": 74152553
  },
  {
    "context": [
      "I want to get only the Value for **DevABC** so that I can use while reading the -r line. I need only DevABC",
      "Assuming all your `Key` values are distinct, you can first convert the array into an object and then access the \"AccountName\" property directly:",
      "jq -r 'from_entries | .AccountName' param.json",
      "If the object keys in the input happen not to be \"Key\" and \"Value\" and you can't use `from_entries`, `select` would be a good approach:",
      "jq --arg k 'AccountName' -r '.[] | select(.Key == $k).Value'"
    ],
    "utterance": "Extract the Value associated with the Key equal to AccountName, which should return DevABC.",
    "expressions": [
      "jq -r 'from_entries | .AccountName'",
      "jq --arg k 'AccountName' -r '.[] | select(.Key == $k).Value'"
    ],
    "data": [
      {
        "input": [
          {
            "Value": "anshuman.ceg+Dev@gmail.com",
            "Key": "AccountEmail"
          },
          {
            "Value": "DevABC",
            "Key": "AccountName"
          },
          {
            "Value": "Security (ou-nzx5-8ajd1561)",
            "Key": "ManagedOrganizationalUnit"
          },
          {
            "Value": "anshuman.ceg+Dev@gmail.com",
            "Key": "SSOUserEmail"
          },
          {
            "Value": "John",
            "Key": "SSOUserFirstName"
          },
          {
            "Value": "Smith",
            "Key": "SSOUserLastName"
          }
        ],
        "output": "DevABC"
      }
    ],
    "identifier": 74160920
  },
  {
    "context": [
      "I have an input row like this: `1374240, 1374241`. I need to make json file: ...",
      "How i can insert it in final json structure and write a file?",
      "echo \"1374240, 1374241\" | jq -R '\n  {version:\"1.0\",tests:(\n    split(\",\") | map(\n      {id: tonumber, selector: \"\"}\n    )\n  )}\n'",
      "Output:\n{\n  \"version\": \"1.0\",\n  \"tests\": [\n    {\n      \"id\": 1374240,\n      \"selector\": \"\"\n    },\n    {\n      \"id\": 1374241,\n      \"selector\": \"\"\n    }\n  ]\n}"
    ],
    "utterance": "Transform a comma-separated list of numbers into an object with version \"1.0\" and a tests array where each number becomes an object with id and an empty selector.",
    "expressions": [
      "echo \"1374240, 1374241\" | jq -R '{version:\"1.0\",tests:(split(\",\") | map({id: tonumber, selector: \"\"}))}'"
    ],
    "data": [
      {
        "input": "1374240, 1374241",
        "output": {
          "version": "1.0",
          "tests": [
            {
              "id": 1374240,
              "selector": ""
            },
            {
              "id": 1374241,
              "selector": ""
            }
          ]
        }
      }
    ],
    "identifier": 74156844
  },
  {
    "context": [
      "I would like to get the following:\r\n{\"field1\":\"test1\",\"field2\":\"test20\",\"field3\":\"test30\",\"array3\":\"11\"}\r\n{\"field1\":\"test1\",\"field2\":\"test20\",\"field3\":\"test30\",\"array3\":\"12\"}\r\n{\"field1\":\"test1\",\"field2\":\"test21\",\"field3\":\"test31\",\"array3\":null}\r\n{\"field1\":\"test1\",\"field2\":\"test22\",\"field3\":\"test32\",\"array3\":null}",
      "This works with your example input:\r\n{field1} + (.array1[] |\r\n  {field2} + (.array2[] |\r\n    {field3} + (\r\n      if has(\"array3\") and (.array3 | length) > 0 then\r\n        {array3: .array3[]}\r\n      else\r\n        {array3: null}\r\n      end\r\n    )\r\n  )\r\n)"
    ],
    "utterance": "Extract objects containing field1, field2, field3, and array3 values, generating one object per element of array3 when present or setting array3 to null if missing or empty.",
    "expressions": [
      "{field1} + (.array1[] | {field2} + (.array2[] | {field3} + (if has(\"array3\") and (.array3 | length) > 0 then {array3: .array3[]} else {array3: null} end)))"
    ],
    "data": [
      {
        "input": {
          "field1": "test1",
          "array1": [
            {
              "field2": "test20",
              "array2": [
                {
                  "field3": "test30",
                  "array3": [
                    "11",
                    "12"
                  ]
                }
              ]
            },
            {
              "field2": "test21",
              "array2": [
                {
                  "field3": "test31",
                  "array3": []
                }
              ]
            },
            {
              "field2": "test22",
              "array2": [
                {
                  "field3": "test32"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "field1": "test1",
            "field2": "test20",
            "field3": "test30",
            "array3": "11"
          },
          {
            "field1": "test1",
            "field2": "test20",
            "field3": "test30",
            "array3": "12"
          },
          {
            "field1": "test1",
            "field2": "test21",
            "field3": "test31",
            "array3": null
          },
          {
            "field1": "test1",
            "field2": "test22",
            "field3": "test32",
            "array3": null
          }
        ]
      }
    ],
    "identifier": 74147897
  },
  {
    "context": [
      "I need a jq filter that would:\r\n* when given `{\"a\": [3, 1, 2]}`, produce `{ \"a\": [1, 2, 3] }`\r\n* when given `{ \"b\": 0 }`, produce `{ \"b\": 0 }`",
      "`.a |= sort` doesn\u2019t work in the second case, because \u201cnull (null) cannot be sorted, as it is not an array\u201d.",
      "From the manual I figured `.a |= try sort` should work. When `.a` is an array, it should just `sort` it. When `.a` is null, `try` should catch the error from `sort` and produce nothing, thus deleting `a`. This works for `{\"b\": 0}`, but for `{ \"a\": [3, 1, 2] }` it produces `{}` instead.",
      "I know other ways to accomplish this, but I want to understand why mine doesn\u2019t work."
    ],
    "utterance": "Sort the array at key a if present, and leave the object unchanged if a is missing.",
    "expressions": [
      "if has(\"a\") and (.a|type==\"array\") then .a|=sort else . end"
    ],
    "data": [
      {
        "input": {
          "a": [
            3,
            1,
            2
          ]
        },
        "output": {
          "a": [
            1,
            2,
            3
          ]
        }
      },
      {
        "input": {
          "b": 0
        },
        "output": {
          "b": 0
        }
      }
    ],
    "identifier": 74165953
  },
  {
    "context": [
      "I\u2019d like to get the keys `a` and `b` as well, and output a flat result, i.e.",
      "$ echo '{\"a\": {\"a1\": 1}, \"b\": {\"a1\": 2}}' | jq -r \"<magic here>\"\na 1\nb 2",
      "jq -r 'to_entries[] | [.key, .value.a1] | @tsv'",
      "jq -r 'keys[] as $key | [$key, .[$key].a1] | @tsv'"
    ],
    "utterance": "List each top-level key and the corresponding value of its a1 field in a flat, tab-separated format.",
    "expressions": [
      "to_entries[] | [.key, .value.a1] | @tsv",
      "keys[] as $key | [$key, .[$key].a1] | @tsv"
    ],
    "data": [
      {
        "input": {
          "a": {
            "a1": 1
          },
          "b": {
            "a1": 2
          }
        },
        "output": "a\t1\nb\t2"
      }
    ],
    "identifier": 74187236
  },
  {
    "context": [
      "I actually need these map entries in comma-delimited key-value pairs. So instead of:\nfizz=buzz foo=baz\n\nI need:\nfizz=buzz,foo=baz",
      "Just join them.\n\njq -r 'to_entries | map(\"\\(.key)=\\(.value)\") | join(\",\")'",
      "jq -r '\n    def values: . as $obj | keys | map($obj[.]);\n    def pairs: [keys, values] | transpose;\n    pairs | map(join(\"=\")) | join(\",\")\n'"
    ],
    "utterance": "Convert a flat mapping of key-value pairs into a single string of comma-separated key=value entries, e.g., fizz=buzz,foo=baz.",
    "expressions": [
      "to_entries | map(\"\\(.key)=\\(.value)\") | join(\",\")",
      "def values: . as $obj | keys | map($obj[.]); def pairs: [keys, values] | transpose; pairs | map(join(\"=\")) | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "fizz": "buzz",
          "foo": "baz"
        },
        "output": "fizz=buzz,foo=baz"
      }
    ],
    "identifier": 74198853
  },
  {
    "context": [
      "I have following JSON\n{\n\t\t\"ID\": \"123\",\n\t\t\"Name\": \"xyz\"\n}\n{\n\t\t\"ID\": \"1234\",\n\t\t\"Competitor\": \"abc\"\n}\n\nNeed to convert the json objects into a array of json objects:\n[\n{\n\t\t\"ID\": \"123\",\n\t\t\"Name\": \"xyz\"\n}\n{\n\t\t\"ID\": \"1234\",\n\t\t\"Competitor\": \"abc\"\n}\n]",
      "If you want to handle a file with multiple documents as a single array document with each original document being an array element, then use `-s`/`--slurp` option which will read all JSON documents in your input file as one huge array:\n\njq -s '.' input.json"
    ],
    "utterance": "Combine multiple top-level objects from a file into a single array of objects, each object being one of the original documents.",
    "expressions": [
      "jq -s '.'"
    ],
    "data": [
      {
        "input": [
          {
            "ID": "123",
            "Name": "xyz"
          },
          {
            "ID": "1234",
            "Competitor": "abc"
          }
        ],
        "output": [
          {
            "ID": "123",
            "Name": "xyz"
          },
          {
            "ID": "1234",
            "Competitor": "abc"
          }
        ]
      }
    ],
    "identifier": 74190473
  },
  {
    "identifier": 74206388
  },
  {
    "context": [
      "How can I pass single values to `.appId`, `.appName` and multiple values to `.groups[]`, `.inclusion[]` all at the same time?",
      "jq --arg appId 123 --argjson groups '[\"your\",\"groups\"]' \\\n  '.appId = $appId | .authSettings.groups = $groups' tpl.json",
      "jq --arg appId \"$appId\"\\\n   --arg appName \"$appName\" \\\n   --argjson groups \"$(jq -n --args '$ARGS.positional' \"${groups[@]}\")\" \\\n   --argjson inclusion \"$(jq -n --args '$ARGS.positional' \"${inclusion[@]}\")\" \\\n   ' .appId = $appId\n     | .appName = $appName\n     | .authSettings.groups = $groups\n     | .authSettings.inclusion = $inclusion\n  ' template.json"
    ],
    "utterance": "Populate .appId and .appName with single variable values, and .authSettings.groups and .authSettings.inclusion arrays with multiple values in a single step.",
    "expressions": [
      ".appId = $appId | .authSettings.groups = $groups",
      ".appId = $appId | .appName = $appName | .authSettings.groups = $groups | .authSettings.inclusion = $inclusion"
    ],
    "data": [
      {
        "input": {
          "appId": "",
          "appName": "",
          "authType": "OIDC",
          "authSettings": {
            "applicationType": "SERVICE",
            "clientAuthenticationType": "CLIENT_SECRET",
            "grantTypes": [
              "CLIENT_CREDENTIALS"
            ],
            "groups": [
              ""
            ],
            "responseTypes": [
              "TOKEN"
            ],
            "inclusion": [
              "",
              "",
              "",
              ""
            ],
            "tokenValidity": {
              "accessTokenLifetimeMinutes": 60,
              "refreshTokenLifetimeMinutes": 10080,
              "refreshTokenWindowMinutes": 1440
            }
          }
        },
        "output": {
          "appId": "1234",
          "appName": "My App",
          "authType": "OIDC",
          "authSettings": {
            "applicationType": "SERVICE",
            "clientAuthenticationType": "CLIENT_SECRET",
            "grantTypes": [
              "CLIENT_CREDENTIALS"
            ],
            "groups": [
              "g1",
              "g2",
              "g3"
            ],
            "responseTypes": [
              "TOKEN"
            ],
            "inclusion": [
              "i1",
              "i2",
              "i3",
              "i4",
              "i5"
            ],
            "tokenValidity": {
              "accessTokenLifetimeMinutes": 60,
              "refreshTokenLifetimeMinutes": 10080,
              "refreshTokenWindowMinutes": 1440
            }
          }
        }
      }
    ],
    "identifier": 74181269
  },
  {
    "context": [
      "The variable from my bash script is `order=\"lasagna\"`.  If `'foods.menu[]'` contains `$order` then do nothing, else insert `$order` value into `'foods.menu[]'`.",
      "jq --arg order lasagna '.foods.menu |= if index($order) then . else . + [$order] end' response.json",
      "jq --arg order 'lasagna' '\n  (.foods.menu | .[index($order) // length]) = $order\n' response.json"
    ],
    "utterance": "Add the value 'lasagna' to 'foods.menu' only if it is not already present.",
    "expressions": [
      ".foods.menu |= if index($order) then . else . + [$order] end",
      "(.foods.menu | .[index($order) // length]) = $order"
    ],
    "data": [
      {
        "input": {
          "foods": {
            "menu": [
              "tacos",
              "spaghetti",
              "pizza",
              "chicken_florentine",
              "bacon_cheeseburge",
              "chow_mein",
              "sushi",
              "chocolate",
              "whiskey"
            ]
          }
        },
        "output": {
          "foods": {
            "menu": [
              "tacos",
              "spaghetti",
              "pizza",
              "chicken_florentine",
              "bacon_cheeseburge",
              "chow_mein",
              "sushi",
              "chocolate",
              "whiskey",
              "lasagna"
            ]
          }
        }
      }
    ],
    "identifier": 74202060
  },
  {
    "context": [
      "If jq is present in the server, how do I populate the USERS and ACTIONS variable?",
      "jq -r 'to_entries[] | \"Executing command \\(.key)-\\(.value[])\"' <<< \"$USER_ACTIONS\"",
      "jq -r 'keys[] as $user | \"Executing command \\($user)-\\(.[$user][])\"' <<< \"$USER_ACTIONS\"",
      "jq -r --stream '\"Executing command \\(.[0][0])-\\(.[1]? // empty)\"' <<< \"$USER_ACTIONS\"",
      "done < <(jq -r 'to_entries[] | [.key, .value[]] | @tsv' <<< \"$user_actions\")"
    ],
    "utterance": "Extract each username and their associated actions as pairs for use in a Bash loop.",
    "expressions": [
      "jq -r 'to_entries[] | \"Executing command \\(.key)-\\(.value[])\"' <<< \"$USER_ACTIONS\"",
      "jq -r 'keys[] as $user | \"Executing command \\($user)-\\(.[$user][])\"' <<< \"$USER_ACTIONS\"",
      "jq -r --stream '\"Executing command \\(.[0][0])-\\(.[1]? // empty)\"' <<< \"$USER_ACTIONS\"",
      "jq -r 'to_entries[] | [.key, .value[]] | @tsv' <<< \"$user_actions\""
    ],
    "data": [
      {
        "input": {
          "user1": [
            "action1"
          ],
          "user2": [
            "action2",
            "action3"
          ]
        },
        "output": [
          "Executing command user1-action1",
          "Executing command user2-action2",
          "Executing command user2-action3"
        ]
      },
      {
        "input": {
          "user1": [
            "action1"
          ],
          "user2": [
            "action2",
            "action3"
          ]
        },
        "output": [
          "user1\taction1",
          "user2\taction2",
          "user2\taction3"
        ]
      }
    ],
    "identifier": 74201919
  },
  {
    "context": [
      "I wish to add the following JSON object at root level to the file above:",
      "{\"heading\": {\"user\": [\"$username\"]}}",
      "Where `$username` is a Bash variable.",
      "jq --arg username \"$username\" '. + {heading: {user: [$username]}}' sample.json"
    ],
    "utterance": "Add an object with key 'heading' containing a 'user' array with the given Bash variable value at the root level.",
    "expressions": [
      "jq --arg username \"$username\" '. + {heading: {user: [$username]}}' sample.json"
    ],
    "data": [
      {
        "input": {
          "api": "3.0.0",
          "data": {
            "description": "something",
            "title": "hello",
            "version": "1.0",
            "app": {
              "name": "abc",
              "id": "xyz"
            }
          }
        },
        "output": {
          "api": "3.0.0",
          "data": {
            "description": "something",
            "title": "hello",
            "version": "1.0",
            "app": {
              "name": "abc",
              "id": "xyz"
            }
          },
          "heading": {
            "user": [
              "$username"
            ]
          }
        }
      }
    ],
    "identifier": 74215374
  },
  {
    "context": [
      "We have to flatten this to a CSV, where each row would be unique containing the data of the JSON object. We would not want any \"new rows\" created from a cross product join. So the above would look like:",
      "In reality, we would want this to be a collection of JSON documents (jq -c).",
      "But now when we try to go further and explode the \"aon\" array of numbers, it gets weird.",
      "can't figure out how to access \"aos\".",
      "\"jq -c '\n  .r1 as $r1\n  | .r2 as $r2\n  | .r3 as $r3\n  | .ver as $ver\n  | .noa1[] \n  | .col1 as $col1\n  | .noa2[] \n  | .aon as $aon\n  | .obj\n  | {$r1, $r2, $ver, $col1, $aon, col10, col11} \n    + try {aos: .aos[]} catch {} '\"",
      "\"If you do, then you could replace the very last {} by {aos: null} or whatever. If you prefer not to use `try ... catch` then you could replace it by an `if` statement, or perhaps by:",
      "( (.aos // [null]) | {aos: .[]} )"
    ],
    "utterance": "Produce a collection where each row uniquely combines top-level values with inner nested array/object fields, expanding 'aon' and 'aos' arrays to individual entries, omitting cross-products and preserving optional fields as null when missing.",
    "expressions": [
      ".r1 as $r1\n| .r2 as $r2\n| .r3 as $r3\n| .ver as $ver\n| .noa1[]\n| .col1 as $col1\n| .noa2[]\n| .aon as $aon\n| .obj\n| {$r1, $r2, $ver, $col1, $aon, col10, col11} + try {aos: .aos[]} catch {}",
      ".r1 as $r1\n| .r2 as $r2\n| .r3 as $r3\n| .ver as $ver\n| .noa1[]\n| .col1 as $col1\n| .noa2[]\n| .aon as $aon\n| .obj\n| {$r1, $r2, $ver, $col1, $aon, col10, col11} + ((.aos // [null]) | {aos: .[]})"
    ],
    "data": [
      {
        "input": {
          "r1": "ex",
          "r2": "of",
          "r3": "da",
          "ver": 1,
          "noa1": [
            {
              "col1": 380,
              "noa2": [
                {
                  "aon": [
                    123
                  ],
                  "obj": {
                    "col10": "stuf",
                    "col11": "here",
                    "aos": [
                      "A",
                      "X"
                    ]
                  }
                },
                {
                  "aon": [],
                  "obj": {
                    "col10": "more",
                    "col11": "stuf"
                  }
                },
                {
                  "aon": [
                    456,
                    789
                  ]
                },
                {
                  "obj": {
                    "col10": "anon"
                  }
                }
              ]
            },
            {
              "col1": 5676,
              "noa2": [
                {
                  "aon": [
                    875
                  ],
                  "obj": {
                    "col10": "does",
                    "col11": "noth",
                    "aos": [
                      "Y",
                      "Z"
                    ]
                  }
                },
                {
                  "obj": {
                    "col11": "phew"
                  }
                }
              ]
            }
          ]
        },
        "output": [
          {
            "r1": "ex",
            "r2": "of",
            "ver": 1,
            "col1": 380,
            "aon": [
              123
            ],
            "col10": "stuf",
            "col11": "here",
            "aos": "A"
          },
          {
            "r1": "ex",
            "r2": "of",
            "ver": 1,
            "col1": 380,
            "aon": [
              123
            ],
            "col10": "stuf",
            "col11": "here",
            "aos": "X"
          },
          {
            "r1": "ex",
            "r2": "of",
            "ver": 1,
            "col1": 380,
            "aon": [],
            "col10": "more",
            "col11": "stuf",
            "aos": null
          },
          {
            "r1": "ex",
            "r2": "of",
            "ver": 1,
            "col1": 380,
            "aon": [
              456,
              789
            ],
            "col10": null,
            "col11": null,
            "aos": null
          },
          {
            "r1": "ex",
            "r2": "of",
            "ver": 1,
            "col1": 380,
            "aon": null,
            "col10": "anon",
            "col11": null,
            "aos": null
          },
          {
            "r1": "ex",
            "r2": "of",
            "ver": 1,
            "col1": 5676,
            "aon": [
              875
            ],
            "col10": "does",
            "col11": "noth",
            "aos": "Y"
          },
          {
            "r1": "ex",
            "r2": "of",
            "ver": 1,
            "col1": 5676,
            "aon": [
              875
            ],
            "col10": "does",
            "col11": "noth",
            "aos": "Z"
          },
          {
            "r1": "ex",
            "r2": "of",
            "ver": 1,
            "col1": 5676,
            "aon": null,
            "col10": null,
            "col11": "phew",
            "aos": null
          }
        ]
      }
    ],
    "identifier": 74103310
  },
  {
    "context": [
      "I have some log files which contain mixed of JSON and non-JSON logs, I'd like to separate them into two files, one contains JSON logs only and the other contains non-JSON logs",
      "For the JSON logs:\n\n    jq -nR -c 'inputs|fromjson?'",
      "For the others, you could use:\n\n    jq -nRr  'inputs | . as $in | try (fromjson|empty) catch $in'"
    ],
    "utterance": "Separate lines containing objects from lines that are not objects and output each group to separate files.",
    "expressions": [
      "jq -nR -c 'inputs|fromjson?'",
      "jq -nRr 'inputs | . as $in | try (fromjson|empty) catch $in'"
    ],
    "data": [
      {
        "input": "{ \"name\": \"joe\"}\ntext line, this can be multi-line too\n{ \"xyz\": 123 }\n",
        "output": "{ \"name\": \"joe\"}\n{ \"xyz\": 123 }\n"
      },
      {
        "input": "{ \"name\": \"joe\"}\ntext line, this can be multi-line too\n{ \"xyz\": 123 }\n",
        "output": "text line, this can be multi-line too\n"
      }
    ],
    "identifier": 74216761
  },
  {
    "context": [
      "Now, while the bash script works fine, I can't seem to be able to get JQ to print multiple returns in one line.",
      "For example, if I do this:",
      "var1 var2 var3 var4 < <(echo $(curl -s 'https://example.com/api/json/APIKEY/'$ip' | jq \".proxy,.vpn,.ISP,.timezone\"))",
      "This is the actual result from CLI command:",
      "`curl -s (...) | jq \".proxy,.vpn,.ISP,.timezone\"",
      "true",
      "true",
      "\"Google Servers\"",
      "\"America/Los_Angeles\"`",
      "You _can_ make jq print items in one line",
      "jq -r '.proxy, .vpn, .ISP, .timezone'",
      "jq -r '.proxy, .vpn, .ISP, .timezone, \"\\u0000\"'",
      "jq -r '(.proxy, .vpn, .ISP, .timezone) | (., \"\\u0000\")'"
    ],
    "utterance": "Output the values of the proxy, vpn, ISP, and timezone fields as a single line with space-separated values, even when field values contain spaces or newlines.",
    "expressions": [
      ".proxy, .vpn, .ISP, .timezone | @tsv",
      "[.proxy, .vpn, .ISP, .timezone] | @tsv",
      "[.proxy, .vpn, .ISP, .timezone] | join(\" \")"
    ],
    "data": [
      {
        "input": {
          "proxy": true,
          "vpn": true,
          "ISP": "Google Servers",
          "timezone": "America/Los_Angeles"
        },
        "output": "true\ttrue\tGoogle Servers\tAmerica/Los_Angeles"
      }
    ],
    "identifier": 74213717
  },
  {
    "context": [
      "`jq -n 'pow(2,4)'`",
      "jq: error: pow/1 is not defined at <top-level>, line 1: pow(2,4) jq: 1 compile error",
      "jq uses semicolons to separate call arguments.",
      "jq -n 'pow(2;4)'",
      "This will call `pow/2` which you are after."
    ],
    "utterance": "Calculate 2 to the power of 4 using the pow function.",
    "expressions": [
      "pow(2;4)"
    ],
    "data": [
      {
        "input": null,
        "output": 16
      }
    ],
    "identifier": 74225724
  },
  {
    "context": [
      "I have many JSON objects where I would like to transform some objects to reduce redundancy and limit some depth.",
      "... I'd like to \"hoist\" the values of all the fields that end in \"List\", e.g., \"foobarList\".",
      "So, the above would be transformed to: ...\n{\n  \"foo\": [\n    {\n      \"foobar\": 2\n    },\n    {\n      \"raboof\": [3, 5, 7]\n    }\n  ],\n  \"baz\": 11,\n  \"foobar\": {\n    \"barbaz\": [13, 17, 19],\n    \"foobaz\": {\n      \"barfoo\": [23, 29]\n    }\n  }\n}",
      "The following produces the answer you want, but may not meet your expectations in every respect:\ndef hoist:\n  with_entries(if (.key | endswith(\"List\")) \n                  and (.value | type == \"object\")\n                  and (.value | keys_unsorted | length==1)\n               then (.value | keys_unsorted[0]) as $k \n               | .key = $k\n               | .value |= .[$k]\n\t           else . end);\n\nwalk(if type == \"object\" then hoist else . end)",
      "If the input is \"hoistable\" structurally, you could also operate on its stream representation:\n[fromstream(tostream | del(.[0][] | select(endswith(\"List\")?)))] | add"
    ],
    "utterance": "Replace all fields whose names end with 'List' by their single key-value pair, effectively hoisting the nested field one level up.",
    "expressions": [
      "def hoist: with_entries(if (.key | endswith(\"List\")) and (.value | type == \"object\") and (.value | keys_unsorted | length==1) then (.value | keys_unsorted[0]) as $k | .key = $k | .value |= .[$k] else . end); walk(if type == \"object\" then hoist else . end)",
      "fromstream(tostream | del(.[0][] | select(endswith(\"List\")?))) | add"
    ],
    "data": [
      {
        "input": {
          "foo": [
            {
              "foobarList": {
                "foobar": 2
              }
            },
            {
              "raboofList": {
                "raboof": [
                  3,
                  5,
                  7
                ]
              }
            }
          ],
          "bazList": {
            "baz": 11
          },
          "foobar": {
            "barbazList": {
              "barbaz": [
                13,
                17,
                19
              ]
            },
            "foobazList": {
              "foobaz": {
                "barfooList": {
                  "barfoo": [
                    23,
                    29
                  ]
                }
              }
            }
          }
        },
        "output": {
          "foo": [
            {
              "foobar": 2
            },
            {
              "raboof": [
                3,
                5,
                7
              ]
            }
          ],
          "baz": 11,
          "foobar": {
            "barbaz": [
              13,
              17,
              19
            ],
            "foobaz": {
              "barfoo": [
                23,
                29
              ]
            }
          }
        }
      }
    ],
    "identifier": 74203127
  },
  {
    "context": [
      "I cannot figure out how to replace values in config_new.json with values from keys that exist in both config.json and config_new.json, recursively, without copying any other attributes from config.json.",
      "So I am trying to override the values in config_new.json only with known values in config.json.",
      "jq -s '[...complex merge function...]' config_new.json config.json",
      "jq --slurpfile cfg config.json '. as $new | reduce (paths(scalars,arrays) | select(any(numbers)|not)) as $path ({}; setpath($path; ($cfg[0]|getpath($path))//($new|getpath($path))))' config_new.json",
      "// expected result\n{\n  \"name\": \"testName\",\n  \"age\": \"tooYoung\",\n  \"properties\": {\n\"title\": \"Mr\",\n\"fruits\": [\"banana\"]\n  },\n}"
    ],
    "utterance": "Recursively replace values in the first object with those from the second object only for keys existing in both, without copying extra keys from the second object.",
    "expressions": [
      "jq -s '\n    def merge($source):\n        . as $target\n        | reduce ($source | keys | map(select(in($target))))[] as $key ($target;\n            .[$key] = if (.[$key] | type) == \"object\"\n                          then .[$key] | merge($source[$key])\n                          else $source[$key]\n                      end\n        )\n    ;\n    . as [$new, $old]\n    | $new | merge($old)\n' config_new.json config.json",
      "jq --slurpfile cfg config.json '. as $new | reduce (paths(scalars,arrays) | select(any(numbers)|not)) as $path ({}; setpath($path; ($cfg[0]|getpath($path))//($new|getpath($path))))' config_new.json",
      ". as $new\n| [$cfg[0] | paths] as $cfg_paths\n| reduce (paths(scalars,arrays) | select(any(numbers)|not)) as $path (\n  {};\n  setpath(\n    $path;\n    $cfg[0] | select($path|IN($cfg_paths[])) // $new \n    | getpath($path)\n  )\n)"
    ],
    "data": [
      {
        "input": {
          "config_new.json": {
            "name": "testName",
            "age": "tooOld",
            "properties": {
              "title": "Mr",
              "fruits": [
                "apple",
                "banana"
              ]
            }
          },
          "config.json": {
            "newName": "changedName",
            "age": "tooYoung",
            "properties": {
              "title": "Mr",
              "height": "tooTall",
              "fruits": [
                "banana"
              ]
            },
            "certificate": "present"
          }
        },
        "output": {
          "name": "testName",
          "age": "tooYoung",
          "properties": {
            "title": "Mr",
            "fruits": [
              "banana"
            ]
          }
        }
      }
    ],
    "identifier": 74195390
  },
  {
    "context": [
      "I am parsing Elastic logs that look like \n```\n$ cat my_log_file.txt:\n{\"level\": \"INFO\", \"message\": \"foo\"}\n{\"level\": \"WARN\", \"message\": \"bar\"}\n{\"level\": \"WARN\", \"message\": \"baz\"}\n```",
      "Now I want to select out only lines that have level != \"INFO\".",
      "How can I convert my records midstream -- after the select is done, to convert the result from\n```\n{\"level\": \"WARN\", \"message\": \"bar\"}\n{\"level\": \"WARN\", \"message\": \"bar\"}\n```\nto \n```\n[\n  {\"level\": \"WARN\", \"message\": \"bar\"},\n  {\"level\": \"WARN\", \"message\": \"bar\"}\n]\n```",
      "The efficient way to make the selection while forming an array is to use `inputs` with the -n command-line option, along the lines of:\n\n    jq -n '[inputs | select(.\"level\" != \"INFO\") ]' my_log_file.txt",
      "If you use slurp, you'll need to wrap the `select` in a `map()` to make it work:\n```\njq -s 'map(select(.level != \"INFO\"))' my_log_file.txt\n```",
      "```\njq -c 'select(.\"level\" != \"INFO\")|reduce inputs as $i ([.];[.]+[$i])' my_log_file.txt\n```"
    ],
    "utterance": "Collect all records where level is not INFO into an array.",
    "expressions": [
      "jq -n '[inputs | select(.\"level\" != \"INFO\")]' my_log_file.txt",
      "jq -s 'map(select(.level != \"INFO\"))' my_log_file.txt",
      "jq -c 'select(.\"level\" != \"INFO\")|reduce inputs as $i ([.];[.]+[$i])' my_log_file.txt"
    ],
    "data": [
      {
        "input": [
          {
            "level": "INFO",
            "message": "foo"
          },
          {
            "level": "WARN",
            "message": "bar"
          },
          {
            "level": "WARN",
            "message": "baz"
          }
        ],
        "output": [
          {
            "level": "WARN",
            "message": "bar"
          },
          {
            "level": "WARN",
            "message": "baz"
          }
        ]
      }
    ],
    "identifier": 74237495
  },
  {
    "context": [
      "My question: how to convert the content to the following format:\r\n\r\nIT,test\r\n\r\nIT,test2\r\n\r\norginazation,hello\r\n\r\norginazation,world\r\n\r\nFin,good\r\n\r\nFin,aaaa\r\n\r\norganization,bbb\r\n\r\norganization,ccc\r\n",
      "First, convert to JSON, then use the jq command.\r\n```\r\nyq eval -o json includelist.yml | \\\r\n    jq -r '.ProductLine.ADO_FeedsList[]|\"\\(.ProjectName),\\(.FeedsName[])\"'\r\n```"
    ],
    "utterance": "Produce lines pairing each ProjectName value with every FeedsName under it, separated by a comma",
    "expressions": [
      ".ProductLine.ADO_FeedsList[]|\"\\(.ProjectName),\\(.FeedsName[])\""
    ],
    "data": [
      {
        "input": [
          {
            "ProductLine": {
              "ProductLineName": "AAAAA",
              "ADO_FeedsList": [
                {
                  "ProjectName": "IT",
                  "FeedsName": [
                    "test",
                    "test2"
                  ]
                },
                {
                  "ProjectName": "organization",
                  "FeedsName": [
                    "hello",
                    "world"
                  ]
                }
              ]
            }
          },
          {
            "ProductLine": {
              "ProductLineName": "BBBBB",
              "ADO_FeedsList": [
                {
                  "ProjectName": "Fin",
                  "FeedsName": [
                    "good",
                    "aaaa"
                  ]
                },
                {
                  "ProjectName": "organization",
                  "FeedsName": [
                    "bbb",
                    "ccc"
                  ]
                }
              ]
            }
          }
        ],
        "output": [
          "IT,test",
          "IT,test2",
          "organization,hello",
          "organization,world",
          "Fin,good",
          "Fin,aaaa",
          "organization,bbb",
          "organization,ccc"
        ]
      }
    ],
    "identifier": 74242155
  },
  {
    "context": [
      "How can I separate into valid and expired certificates? (As a stretch goal, I'd like to sort the expired certificates to print in output first).",
      "Consider doing the filtering inside of jq itself:",
      "jq \\\n  --arg now_epoch \"$(date +%s --date='30 days ago')\" '\n  ($now_epoch | strptime(\"%s\")) as $now\n| .[]\n| (.notafter | strptime(\"%d %b %Y %H:%M:%S GMT\")) as $expire_time\n| if $now > $expire_time\n  then \"Expired cert for \\(.subject)\"\n  else \"Valid cert for \\(.subject)\"\n  end'",
      "To add the sorting, one might change it to:",
      "jq -n   --arg now_epoch \"$(date +%s --date='30 days ago')\" '\n  ($now_epoch | strptime(\"%s\")) as $now\n| [ inputs[]\n    | (.notafter | strptime(\"%d %b %Y %H:%M:%S GMT\")) as $expire_time\n    | [ $expire_time,\n         if $now > $expire_time\n         then \"Expired cert for \\(.subject)\"\n         else \"Valid cert for \\(.subject)\"\n         end\n       ]\n  ]\n| sort[]\n| .[1]\n'"
    ],
    "utterance": "List certificates, marking each as expired or valid depending on whether their notafter date (converted to epoch) is before or after a cutoff epoch, and sort so expired certificates appear first.",
    "expressions": [
      "jq \\\n  --arg now_epoch \"$(date +%s --date='30 days ago')\" '\n  ($now_epoch | strptime(\"%s\")) as $now\n| .[]\n| (.notafter | strptime(\"%d %b %Y %H:%M:%S GMT\")) as $expire_time\n| if $now > $expire_time\n  then \"Expired cert for \\(.subject)\"\n  else \"Valid cert for \\(.subject)\"\n  end'",
      "jq -n   --arg now_epoch \"$(date +%s --date='30 days ago')\" '\n  ($now_epoch | strptime(\"%s\")) as $now\n| [ inputs[]\n    | (.notafter | strptime(\"%d %b %Y %H:%M:%S GMT\")) as $expire_time\n    | [ $expire_time,\n         if $now > $expire_time\n         then \"Expired cert for \\(.subject)\"\n         else \"Valid cert for \\(.subject)\"\n         end\n       ]\n  ]\n| sort[]\n| .[1]\n'"
    ],
    "data": [
      {
        "input": [
          {
            "notafter": "1 May 2024 14:21:51 GMT",
            "subject": "CN=Valid Certificate B"
          },
          {
            "notafter": "2 Jan 2000 00:00:00 GMT",
            "subject": "CN=Expired Certificate B"
          },
          {
            "notafter": "30 Apr 2024 14:21:51 GMT",
            "subject": "CN=Valid Certificate A"
          },
          {
            "notafter": "1 Jan 2000 00:00:00 GMT",
            "subject": "CN=Expired Certificate A"
          }
        ],
        "output": [
          "Valid cert for CN=Valid Certificate B",
          "Expired cert for CN=Expired Certificate B",
          "Valid cert for CN=Valid Certificate A",
          "Expired cert for CN=Expired Certificate A"
        ]
      }
    ],
    "identifier": 74240376
  },
  {
    "context": [
      "I have problems to filter out missing objects without one out of two values (EMAIL,JOB_TITLE).",
      "The list that I try to create:\n\n```\n\"john.doe@contoso.com\": \"SALESMAN\",\n\"lorraine.doe@contoso.com\": \"SECRETARY\"\n```",
      "This turns the attributes array into an object using `from_entries`, filters according to the presence of both keys using `select` and `has`, and extracts the values required using [string interpolation](https://stedolan.github.io/jq/manual/#Stringinterpolation-%5C%28foo%29):",
      "jq -r '\n  .[].attributes | from_entries\n  | select(has(\"JOB_TITLE\") and has(\"EMAIL\"))\n  | \"\\\"\\(.EMAIL)\\\": \\\"\\(.JOB_TITLE)\\\"\"\n'",
      "\"john.doe@contoso.com\": \"SALESMAN\"\n\"lorraine.doe@contoso.com\": \"SECRETARY\""
    ],
    "utterance": "Extract all top-level objects that have both an EMAIL and JOB_TITLE attribute, and list each EMAIL as a key with the JOB_TITLE as its value.",
    "expressions": [
      ".[].attributes | from_entries | select(has(\"JOB_TITLE\") and has(\"EMAIL\")) | \"\\\"\\(.EMAIL)\\\": \\\"\\(.JOB_TITLE)\\\"\""
    ],
    "data": [
      {
        "input": [
          {
            "primary": "JOHN DOE",
            "attributes": [
              {
                "type": "double",
                "name": "BUILDING_NUMBER",
                "value": "123"
              },
              {
                "type": "double",
                "name": "FLOOR",
                "value": 10
              },
              {
                "type": "string",
                "name": "EMAIL",
                "value": "john.doe@contoso.com"
              },
              {
                "type": "string",
                "name": "JOB_TITLE",
                "value": "SALESMAN"
              }
            ],
            "aliases": [
              {
                "alias": "joao.doe@contoso.com"
              }
            ]
          },
          {
            "primary": "LORRAINE DOE",
            "attributes": [
              {
                "type": "double",
                "name": "BUILDING_NUMBER",
                "value": 456
              },
              {
                "type": "double",
                "name": "FLOOR",
                "value": 10
              },
              {
                "type": "string",
                "name": "STATUS",
                "value": "Unavaliable"
              },
              {
                "type": "string",
                "name": "EMAIL",
                "value": "lorraine.doe@contoso.com"
              },
              {
                "type": "string",
                "name": "JOB_TITLE",
                "value": "SECRETARY"
              }
            ],
            "aliases": [
              {
                "alias": "lorris.doe@contoso.com"
              },
              {
                "alias": "lorris2.doe@contoso.com"
              }
            ]
          },
          {
            "primary": "JACK DOE",
            "attributes": [
              {
                "type": "double",
                "name": "BUILDING_NUMBER",
                "value": "123"
              },
              {
                "type": "double",
                "name": "FLOOR",
                "value": 10
              },
              {
                "type": "string",
                "name": "JOB_TITLE",
                "value": "OWNER"
              }
            ],
            "aliases": [
              {
                "alias": "jack.doe@contoso.com"
              },
              {
                "alias": "jackson.doe@contoso.com"
              }
            ]
          },
          {
            "primary": "NOAH DOE",
            "attributes": [
              {
                "type": "double",
                "name": "BUILDING_NUMBER",
                "value": "123"
              },
              {
                "type": "double",
                "name": "FLOOR",
                "value": 10
              },
              {
                "type": "string",
                "name": "EMAIL",
                "value": "noah.doe@contoso.com"
              }
            ],
            "aliases": [
              {
                "alias": "noah.doe95@contoso.com"
              }
            ]
          }
        ],
        "output": [
          "\"john.doe@contoso.com\": \"SALESMAN\"",
          "\"lorraine.doe@contoso.com\": \"SECRETARY\""
        ]
      }
    ],
    "identifier": 74214912
  },
  {
    "context": [
      "We need to replace the Existing TargetOriginID with New Values.",
      "jq -r '(.CacheBehaviors.Items[].TargetOriginId | select(. == \"$targetoriginID\")) = \"$NewValue\"' distconfig.json > \"tmp\" && mv \"tmp\" distconfig.json",
      "It selects all `TargetOriginId`s which contain the value `\"nkl\"` and changes the list to only contain `\"wkl\"`.",
      "(.CacheBehaviors.Items[].TargetOriginId | select(. == [\"nkl\"])) = [\"wkl\"]",
      "jq: (.CacheBehaviors.Items[].TargetOriginId[] | select(. == \"nkl\")) = \"wkl\"",
      "Assuming you want to define a mapping \"{old1: new1, old2: new2, old3: new3, \u2026}\", the following program could work and is easily extendable:",
      "(.CacheBehaviors.Items[].TargetOriginId[]) |= ({\n  nkl: \"wkl\",\n  xyz: \"123\",\n  \"something else\": \"is changed too\",\n  \"not found\": \"never replaced\"\n}[.] // .)",
      "jq --slurpfile mapping old_to_new_ids.json \\\n  '(.CacheBehaviors.Items[].TargetOriginId[]) |= ($mapping[0][.] // .)'"
    ],
    "utterance": "Replace every occurrence of a given TargetOriginId value in all CacheBehaviors items with new values according to a mapping.",
    "expressions": [
      "(.CacheBehaviors.Items[].TargetOriginId[] | select(. == \"nkl\")) = \"wkl\"",
      "(.CacheBehaviors.Items[].TargetOriginId[]) |= ({\n  nkl: \"wkl\",\n  xyz: \"123\",\n  \"something else\": \"is changed too\",\n  \"not found\": \"never replaced\"\n}[.] // .)",
      "jq --slurpfile mapping old_to_new_ids.json '(.CacheBehaviors.Items[].TargetOriginId[]) |= ($mapping[0][.] // .)'"
    ],
    "data": [
      {
        "input": {
          "CacheBehaviors": {
            "Quantity": 2,
            "Items": [
              {
                "PathPattern": "jkl/*",
                "TargetOriginId": [
                  "nkl",
                  "something else"
                ]
              },
              {
                "PathPattern": "fgh/*",
                "TargetOriginId": [
                  "xyz",
                  "abc"
                ]
              }
            ]
          },
          "IsIPV6Enabled": true
        },
        "output": {
          "CacheBehaviors": {
            "Quantity": 2,
            "Items": [
              {
                "PathPattern": "jkl/*",
                "TargetOriginId": [
                  "wkl",
                  "is changed too"
                ]
              },
              {
                "PathPattern": "fgh/*",
                "TargetOriginId": [
                  "123",
                  "abc"
                ]
              }
            ]
          },
          "IsIPV6Enabled": true
        }
      }
    ],
    "identifier": 74232966
  },
  {
    "context": [
      "Check if `artifacts_file` key exists in each iteration and if it does return the (job) id (so `.[].id`)",
      "Check if `artifacts` array is empty in each iteration and if it is empty return the (job) id.",
      "Checking the existence of a field using `has`:\n~~~sh\n.[] | select(has(\"artifacts_file\")).id\n~~~",
      "Checking if a field is an empty array by comparing it to `[]`:\n~~~sh\n.[] | select(.artifacts == []).id\n~~~"
    ],
    "utterance": "Return the job id for each entry where artifacts_file exists, or where the artifacts array is empty.",
    "expressions": [
      ".[] | select(has(\"artifacts_file\")).id",
      ".[] | select(.artifacts == []).id"
    ],
    "data": [
      {
        "input": [
          {
            "id": 3219589880,
            "status": "success",
            "stage": "test",
            "name": "job_with_no_artifact",
            "ref": "main",
            "tag": false,
            "coverage": null,
            "allow_failure": false,
            "created_at": "2022-10-24T18:21:25.119Z",
            "started_at": "2022-10-24T18:21:25.986Z",
            "finished_at": "2022-10-24T18:21:38.464Z",
            "duration": 12.478682,
            "queued_duration": 0.499786,
            "user": {
              "id": 123456789
            },
            "commit": {
              "id": "5e0e1f287d20daf2036a3ca71c656dce55999265"
            },
            "pipeline": {
              "id": 123456789,
              "project": {
                "ci_job_token_scope_enabled": false
              }
            },
            "artifacts": [],
            "runner": {
              "id": 12270859
            },
            "artifacts_expire_at": null,
            "tag_list": []
          },
          {
            "id": 3219589878,
            "status": "success",
            "stage": "test",
            "name": "create_artifact_job_2",
            "ref": "main",
            "tag": false,
            "coverage": null,
            "allow_failure": false,
            "created_at": "2022-10-24T18:21:25.111Z",
            "started_at": "2022-10-24T18:21:25.922Z",
            "finished_at": "2022-10-24T18:21:39.090Z",
            "duration": 13.168405,
            "queued_duration": 0.464364,
            "user": {
              "id": 123456789
            },
            "commit": {
              "id": "5e0e1f287d20daf2036a3ca71c656dce55999265"
            },
            "pipeline": {
              "id": 675641982,
              "project": {
                "ci_job_token_scope_enabled": false
              }
            },
            "artifacts_file": {
              "filename": "artifacts.zip",
              "size": 223
            },
            "artifacts": [
              {
                "file_type": "archive",
                "size": 223,
                "filename": "artifacts.zip",
                "file_format": "zip"
              },
              {
                "file_type": "metadata",
                "size": 153,
                "filename": "metadata.gz",
                "file_format": "gzip"
              }
            ],
            "runner": {
              "id": 12270845
            },
            "artifacts_expire_at": "2022-10-25T18:21:35.859Z",
            "tag_list": []
          },
          {
            "id": 3219589876,
            "status": "success",
            "stage": "test",
            "name": "create_artifact_job_1",
            "ref": "main",
            "tag": false,
            "coverage": null,
            "allow_failure": false,
            "created_at": "2022-10-24T18:21:25.103Z",
            "started_at": "2022-10-24T18:21:25.503Z",
            "finished_at": "2022-10-24T18:21:41.407Z",
            "duration": 15.904028,
            "queued_duration": 0.098837,
            "user": {
              "id": 123456789
            },
            "commit": {
              "id": "5e0e1f287d20daf2036a3ca71c656dce55999265"
            },
            "pipeline": {
              "id": 123456789
            },
            "web_url": "WEB_URL",
            "project": {
              "ci_job_token_scope_enabled": false
            },
            "artifacts_file": {
              "filename": "artifacts.zip",
              "size": 217
            },
            "artifacts": [
              {
                "file_type": "archive",
                "size": 217,
                "filename": "artifacts.zip",
                "file_format": "zip"
              },
              {
                "file_type": "metadata",
                "size": 152,
                "filename": "metadata.gz",
                "file_format": "gzip"
              }
            ],
            "runner": {
              "id": 12270857
            },
            "artifacts_expire_at": "2022-10-25T18:21:37.808Z",
            "tag_list": []
          }
        ],
        "output": {
          "has_artifacts_file": [
            3219589878,
            3219589876
          ],
          "artifacts_empty": [
            3219589880
          ]
        }
      }
    ],
    "identifier": 74187141
  }
]