[
  {
    "context": [
      "As far as I can understand from the [manual](https://stedolan.github.io/jq/manual/v1.6/#Update-assignment%3A%7C%3D), update-assignment (`|=`) is supposed to assign the RHS to every path on the LHS, and if the RHS is `empty` it should delete the path.",
      "$ echo '[1, 2]' | jq -c 'del(.[])'\n[]",
      "$ echo '[1, 2]' | jq -c '.[] |= empty'\n[2]",
      "the workaround of using `del` works just fine (as I showed in the question)"
    ],
    "utterance": "Remove all elements from the top-level array.",
    "expressions": [
      "del(.[])"
    ],
    "data": [
      {
        "input": [
          1,
          2
        ],
        "output": []
      }
    ],
    "identifier": 76207747
  },
  {
    "context": [
      "And I want output that looks like:\r\n\r\n```\r\n                 RUN   DONE   EXIT\r\ncompute-node-1   1     1      1\r\ncompute-node-2   2\r\n\r\n```",
      "jq -r '\r\n  .RECORDS \r\n  | (map(.STAT) | unique) as $statuses\r\n  | reduce .[] as $x (null; .[$x.EXEC_HOST][$x.STAT] += 1)\r\n  | [null, $statuses[]],\r\n     (to_entries[] | [.key, .value[$statuses[]]])\r\n  | @tsv\r\n'"
    ],
    "utterance": "Produce a summary table counting, for each host, the number of jobs by status, with statuses as columns and hosts as rows.",
    "expressions": [
      ".RECORDS \n| (map(.STAT) | unique) as $statuses\n| reduce .[] as $x (null; .[$x.EXEC_HOST][$x.STAT] += 1)\n| [null, $statuses[]],\n   (to_entries[] | [.key, .value[$statuses[]]])\n| @tsv"
    ],
    "data": [
      {
        "input": {
          "COMMAND": "bjobs",
          "JOBS": 5,
          "RECORDS": [
            {
              "EXEC_HOST": "compute-node-1",
              "STAT": "RUN"
            },
            {
              "EXEC_HOST": "compute-node-1",
              "STAT": "DONE"
            },
            {
              "EXEC_HOST": "compute-node-2",
              "STAT": "RUN"
            },
            {
              "EXEC_HOST": "compute-node-1",
              "STAT": "EXIT"
            },
            {
              "EXEC_HOST": "compute-node-2",
              "STAT": "RUN"
            }
          ]
        },
        "output": "\tDONE\tEXIT\tRUN\ncompute-node-1\t1\t1\t1\ncompute-node-2\t\t\t2"
      }
    ],
    "identifier": 76223335
  },
  {
    "context": [
      "With the proper tool: [`jq`](https://github.com/stedolan/jq):",
      "jq ' [ .[], \"inputstring\" ] ' file",
      "To edit _in place_: jq ' [ .[], \"inputstring\" ] ' file | sponge file",
      "You can use `+=` to update the array. Also, use `--arg` to import a string from outside jq.",
      "jq --arg s 'inputstring' '. += [$s]' file.json",
      "Solution to my case based on the kind answers. I couldn't use `sponge` command and was using `find` this time:",
      "jq --argjson s \"[\\\"inputstring\\\"]\" \". += \\$s\" \"{}\""
    ],
    "utterance": "Append the string \"inputstring\" as a new element to the end of every top-level array in multiple files named settings.json.",
    "expressions": [
      "[ .[], \"inputstring\" ]",
      ". += [\"inputstring\"]",
      "jq --arg s 'inputstring' '. += [$s]' file.json",
      "jq --argjson s '[\"inputstring\"]' '. += $s' file.json"
    ],
    "data": [
      {
        "input": [
          "data1",
          "data2",
          "data(n)"
        ],
        "output": [
          "data1",
          "data2",
          "data(n)",
          "inputstring"
        ]
      }
    ],
    "identifier": 76196662
  },
  {
    "context": [
      "I have this sort of json:\n\n[\n    {\n        \"source\": \n        {\n            \"file\": \"test\",\n            \"baz\": \"now\"\n        }\n    },\n    {\n        \"source\": {\n            \"dev\": \"foo\"\n        }\n    },\n    \n    {\n        \"source\": {\n            \"bar\": \"bar\"\n        }\n    }\n]\n\nand I would like to get a list of all values for `file` or `dev`. So the expected outcome of the above should be: [\"test\", \"foo\"]",
      "map(.source | .file, .dev | values)",
      "map(.source[\"file\", \"dev\"] | values)",
      "[ getpath(paths | select(.[-1] == \"file\" or .[-1] == \"dev\")) ]",
      "[ tostream | select(.[1] and (.[0][-1] | IN(\"file\", \"dev\"))) | .[1] ]"
    ],
    "utterance": "Extract all values associated with the keys 'file' or 'dev' from the 'source' field in an array of objects.",
    "expressions": [
      "map(.source | .file, .dev | values)",
      "map(.source[\"file\", \"dev\"] | values)",
      "[ getpath(paths | select(.[-1] == \"file\" or .[-1] == \"dev\")) ]",
      "[ tostream | select(.[1] and (.[0][-1] | IN(\"file\", \"dev\"))) | .[1] ]"
    ],
    "data": [
      {
        "input": [
          {
            "source": {
              "file": "test",
              "baz": "now"
            }
          },
          {
            "source": {
              "dev": "foo"
            }
          },
          {
            "source": {
              "bar": "bar"
            }
          }
        ],
        "output": [
          "test",
          "foo"
        ]
      }
    ],
    "identifier": 76199666
  },
  {
    "context": [
      "I would like the output to look like this:",
      "{\n  \"accounts\": [\n    {\n      \"group\": 1,\n      \"name\": \"John\",\n      \"id\": 1\n    },\n    {\n      \"group\": 1,\n      \"name\": \"Jane\",\n      \"id\": 2\n    },\n    {\n      \"group\": 2,\n      \"name\": \"Bob\",\n      \"id\": 3\n    },\n    {\n      \"group\": 2,\n      \"name\": \"Mary\",\n      \"id\": 3\n    }\n  ]\n}",
      "How do I use `jq` to accomplish this?",
      "Add each item of the `.users` array to the single `{group}` item. Do it for all items in the `.accounts` array using `map`, and do it in place using an update-assignment `|=`:",
      "jq '.accounts |= map({group} + .users[])' file.json"
    ],
    "utterance": "Produce an object with an 'accounts' key containing a flat array of objects, each combining the 'group' from the parent and the 'name' and 'id' from each user.",
    "expressions": [
      ".accounts |= map({group} + .users[])"
    ],
    "data": [
      {
        "input": {
          "accounts": [
            {
              "group": 1,
              "users": [
                {
                  "name": "John",
                  "id": 1
                },
                {
                  "name": "Jane",
                  "id": 2
                }
              ]
            },
            {
              "group": 2,
              "users": [
                {
                  "name": "Bob",
                  "id": 3
                },
                {
                  "name": "Mary",
                  "id": 3
                }
              ]
            }
          ]
        },
        "output": {
          "accounts": [
            {
              "group": 1,
              "name": "John",
              "id": 1
            },
            {
              "group": 1,
              "name": "Jane",
              "id": 2
            },
            {
              "group": 2,
              "name": "Bob",
              "id": 3
            },
            {
              "group": 2,
              "name": "Mary",
              "id": 3
            }
          ]
        }
      }
    ],
    "identifier": 76230610
  },
  {
    "context": [
      "I want to retrieve in my shell the password when login is \"vault keystore password\".",
      "First iterare over the array, then select by criteria:",
      "jq -r '.data.system[] | select(.login == \"vault keystore password\").password'",
      ".data.system | map(select(.login == \"vault keystore password\"))[].password",
      ".data.system | .[] |select(.login==\"vault keystore password\").password"
    ],
    "utterance": "Return the password for the entry whose login is \"vault keystore password\".",
    "expressions": [
      ".data.system[] | select(.login == \"vault keystore password\").password",
      ".data.system | map(select(.login == \"vault keystore password\"))[].password",
      ".data.system | .[] | select(.login==\"vault keystore password\").password"
    ],
    "data": [
      {
        "input": {
          "data": {
            "system": [
              {
                "login": "vault keystore password",
                "password": "123456"
              },
              {
                "login": "vault keystore masked",
                "password": "MASK-789101112"
              },
              {
                "login": "vault salt",
                "password": "toto"
              },
              {
                "login": "vault iteration",
                "password": "10"
              },
              {
                "login": "keystore Alias",
                "password": "vault"
              }
            ]
          }
        },
        "output": "123456"
      }
    ],
    "identifier": 76235231
  },
  {
    "context": [
      "i am trying to update my json file as following",
      "jq  .attributes.DeployVersion.default=0.0.1 block.json > t.tmp && mv t.tmp block.json",
      "which throws an error",
      "jq: error: Invalid numeric literal at EOF at line 1, column 5 (while parsing '0.0.0') at <top-level>, line 1:",
      ".attributes.DeployVersion.default=0.0.1",
      "while this:",
      "jq  .attributes.DeployVersion.default=0.1  block.json > t.tmp && mv t.tmp block.json",
      "works perfectly (the only difference is instead of 0.0.1 I use 0.1)",
      "Quotes around both the version string and the whole expression:",
      "jq -r '.attributes.DeployVersion.default=\"0.0.2\"'",
      "Or escape the quotes around the version string:",
      "jq -r .attributes.deployVersion.default=\\\"0.0.2\\\""
    ],
    "utterance": "Update the .attributes.DeployVersion.default value to the string 0.0.2",
    "expressions": [
      ".attributes.DeployVersion.default=\"0.0.2\"",
      ".attributes.deployVersion.default=\"0.0.2\""
    ],
    "identifier": 76248117
  },
  {
    "context": [
      "I want to transform it to the table like this:",
      "c\td\ta\tb\te",
      "3\t2\t1\t4\t<absent>",
      "7\t6\t5\t8\t9",
      "So:",
      "- Columns `c` and `d` are moved to the beginning of the table;",
      "- All other columns are sorted alphabetically.",
      "If the key names are known, you could pre-define their order in a variable as an array, then use that for the header as well as the columns in each row.",
      "If the `<absent>` string was intended to be inserted literally, use `//` to provide an alternative content:",
      "[\"c\",\"d\",\"a\",\"b\",\"e\"] as $keys\n| $keys, (.data[] | [.[$keys[]] | . // \"<absent>\"])\n| @tsv",
      "Then scan the keys first, make a `unique` list, drop `c` and `d`, and prepend them. This is your dynamic `$keys` variable.",
      ".data\n| (map(to_entries[].key | select(IN(\"c\", \"d\") | not)) | [\"c\",\"d\"] + unique) as $keys\n| $keys, (.[] | [.[$keys[]] | . // \"<absent>\"])\n| @tsv",
      ".data\n| [\"c\",\"d\"] as $cd\n| ($cd + (add|keys - $cd)) as $keys\n| $keys, [.[][$keys[]] // \"<absent>\"]\n| @tsv"
    ],
    "utterance": "Convert the array of objects to a table where columns 'c' and 'd' appear first, all other columns are sorted alphabetically, and missing values are represented by '<absent>'.",
    "expressions": [
      "[\"c\",\"d\",\"a\",\"b\",\"e\"] as $keys\n| $keys, (.data[] | [.[$keys[]] | . // \"<absent>\"])\n| @tsv",
      ".data\n| (map(to_entries[].key | select(IN(\"c\", \"d\") | not)) | [\"c\",\"d\"] + unique) as $keys\n| $keys, (.[] | [.[$keys[]] | . // \"<absent>\"])\n| @tsv",
      ".data\n| [\"c\",\"d\"] as $cd\n| ($cd + (add|keys - $cd)) as $keys\n| $keys, [.[][$keys[]] // \"<absent>\"]\n| @tsv"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "a": 1,
              "d": 2,
              "c": 3,
              "b": 4
            },
            {
              "a": 5,
              "d": 6,
              "c": 7,
              "b": 8,
              "e": 9
            }
          ]
        },
        "output": "c\td\ta\tb\te\n3\t2\t1\t4\t<absent>\n7\t6\t5\t8\t9"
      }
    ],
    "identifier": 76230620
  },
  {
    "context": [
      "Now, I want to find all the cities inside the xls array where the value is equal to form.state. I want to create a jq expression which can do this.",
      ".form.state as $c | .xls[] | select(.state == $c).city",
      "Your attempt doesn&#39;t work, because once you descend into the `xls` leaf path, there is no way to get the value of `.form.state`, unless you store it in a variable."
    ],
    "utterance": "List all cities from the 'xls' array where the state's value equals the value in 'form.state'.",
    "expressions": [
      ".form.state as $c | .xls[] | select(.state == $c).city"
    ],
    "data": [
      {
        "input": {
          "form": {
            "state": "MH"
          },
          "xls": [
            {
              "state": "MH",
              "channel": 1,
              "city": "Pune"
            },
            {
              "state": "MH",
              "channel": 1,
              "city": "Nashik"
            },
            {
              "state": "MH",
              "channel": 2,
              "city": "Solapur"
            },
            {
              "state": "MH",
              "channel": 2,
              "city": "Nagpur"
            },
            {
              "state": "KAR",
              "channel": 1,
              "city": "Mysore"
            },
            {
              "state": "KAR",
              "channel": 1,
              "city": "Bijapur"
            },
            {
              "state": "KAR",
              "channel": 2,
              "city": "Bellary"
            },
            {
              "state": "KAR",
              "channel": 2,
              "city": "Mangalore"
            }
          ]
        },
        "output": [
          "Pune",
          "Nashik",
          "Solapur",
          "Nagpur"
        ]
      }
    ],
    "identifier": 76236956
  },
  {
    "identifier": 76266656
  },
  {
    "context": [
      "From the json change_tasks array below I would like to extract only the values of the key \"description\" when the key:value is an exact match of \"short_description\": \"01. Project validation\".",
      "This query gives me the output of the correct change task but I only require the values of \"description\" when \"short_description\" is \"01. Project validation\". Also the change tasks value I want will not always be [1] it could be any in the list of objects.",
      "You can use:",
      "$ jq -r '.change_tasks[] | select(.short_description == \"01. Project validation\").description | gsub(\",\\\\s+\";\",\") | split(\",\") | @sh ' test.json",
      "variable=$(jq -r '.change_tasks[] | select(.short_description==\"01. Project validation\").description' test.json)"
    ],
    "utterance": "Extract the description value for each object where short_description is exactly '01. Project validation'.",
    "expressions": [
      ".change_tasks[] | select(.short_description == \"01. Project validation\").description"
    ],
    "data": [
      {
        "input": {
          "change_tasks": [
            {
              "active": "true",
              "approval": "Not Yet Requested",
              "description": "testing",
              "short_description": "Test description",
              "state": "-5",
              "state_description": "Pending",
              "sys_class_name": "Change Task",
              "sys_created_on": "2023-05-10 15:23:50",
              "sys_updated_on": "2023-05-10 15:25:58",
              "time_worked": "",
              "u_actions_taken_to_prevent_recurrence": "",
              "u_createdby_businessappid": ""
            },
            {
              "active": "true",
              "approval": "Not Yet Requested",
              "description": "value-01, value-02",
              "short_description": "01. Project validation",
              "state": "-5",
              "state_description": "Pending",
              "sys_class_name": "Change Task",
              "sys_created_on": "2023-05-10 15:21:01",
              "sys_updated_on": "2023-05-10 15:25:58",
              "time_worked": "",
              "u_actions_taken_to_prevent_recurrence": "",
              "u_createdby_businessappid": ""
            }
          ],
          "responseSummary": {
            "message": "Search successfully executed",
            "code": "200",
            "businessUnit": "unit1",
            "businessAppId": "123456",
            "numRecordsReturned": "2",
            "totalRecords": "2",
            "hasMore": "false"
          }
        },
        "output": "value-01, value-02"
      }
    ],
    "identifier": 76255433
  },
  {
    "context": [
      "In bash, I need to go through this data, to update the `password` for all `auditX` objects.",
      "You can filter for objects using `select(type == \"object\")`, or use its shortcut equivalent `objects`:",
      "(.[] | select(type == \"object\" and has(\"auditScore\"))).password = \"X\"",
      "(.[] | objects | select(has(\"auditScore\"))).password = \"X\""
    ],
    "utterance": "Set the password field to a new value for every top-level object that contains an auditScore key.",
    "expressions": [
      "(.[] | select(type == \"object\" and has(\"auditScore\"))).password = \"X\"",
      "(.[] | objects | select(has(\"auditScore\"))).password = \"X\""
    ],
    "data": [
      {
        "input": {
          "storageSummary": "testvalue",
          "audit1": {
            "auditScore": 1,
            "suspensionScore": 1,
            "password": "value1",
            "onlineScore": 0.99743587,
            "satelliteName": "us2.storj.io:7777"
          },
          "audit2": {
            "auditScore": 1,
            "suspensionScore": 1,
            "password": "valueX",
            "onlineScore": 0.9992917,
            "satelliteName": "saltlake.tardigrade.io:7777"
          },
          "audit3": {
            "auditScore": 1,
            "suspensionScore": 1,
            "password": "value72",
            "onlineScore": 0.99930555,
            "satelliteName": "ap1.storj.io:7777"
          }
        },
        "output": {
          "storageSummary": "testvalue",
          "audit1": {
            "auditScore": 1,
            "suspensionScore": 1,
            "password": "X",
            "onlineScore": 0.99743587,
            "satelliteName": "us2.storj.io:7777"
          },
          "audit2": {
            "auditScore": 1,
            "suspensionScore": 1,
            "password": "X",
            "onlineScore": 0.9992917,
            "satelliteName": "saltlake.tardigrade.io:7777"
          },
          "audit3": {
            "auditScore": 1,
            "suspensionScore": 1,
            "password": "X",
            "onlineScore": 0.99930555,
            "satelliteName": "ap1.storj.io:7777"
          }
        }
      }
    ],
    "identifier": 76254127
  },
  {
    "context": [
      "I want to print only the value of displayName when '\"some_condition\"' doesnt exists or value is null.",
      ".entities[] | select(.properties.kubernetesLabels.some_condition==null) | .displayName"
    ],
    "utterance": "Print the displayName of all entities where properties.kubernetesLabels.some_condition is null or does not exist.",
    "expressions": [
      ".entities[] | select(.properties.kubernetesLabels.some_condition == null) | .displayName"
    ],
    "data": [
      {
        "input": {
          "entities": [
            {
              "displayName": "host123.bcbsfl.com",
              "properties": {
                "kubernetesLabels": {
                  "kubernetes.io/hostname": "host123.bcbsfl.com",
                  "some_condition": "true",
                  "kubernetes.io/arch": "amd64",
                  "kubernetes.io/os": "linux",
                  "beta.kubernetes.io/arch": "amd64",
                  "node.openshift.io/os_id": "rhcos",
                  "beta.kubernetes.io/os": "linux",
                  "node-role.kubernetes.io/worker": ""
                }
              }
            },
            {
              "displayName": "host567.abc.com",
              "properties": {
                "kubernetesLabels": {
                  "kubernetes.io/hostname": "host567.abc.com",
                  "kubernetes.io/arch": "amd64",
                  "kubernetes.io/os": "linux",
                  "beta.kubernetes.io/arch": "amd64",
                  "node.openshift.io/os_id": "rhcos",
                  "beta.kubernetes.io/os": "linux",
                  "node-role.kubernetes.io/worker": ""
                }
              }
            }
          ]
        },
        "output": "host567.abc.com"
      }
    ],
    "identifier": 76266479
  },
  {
    "context": [
      "echo $in_stock | jq 'contains([\"$favorite_food\"])'",
      "echo $in_stock | jq --arg item \"$favorite_food\" 'contains([$item])'"
    ],
    "utterance": "Check if an array contains a value stored in a shell variable.",
    "expressions": [
      "jq --arg item \"$favorite_food\" 'contains([$item])'"
    ],
    "data": [
      {
        "input": [
          "orange",
          "apple",
          "pickle"
        ],
        "output": true
      }
    ],
    "identifier": 76266678
  },
  {
    "context": [
      "I want to go through it: when the `auditScore` is 1, I need to store the parent object name (like `audit1`), and the `onlineScore`.",
      "So, I need to extract the `parent object name` instead of the `satelliteName` in this code.",
      "You can use [`to_entries`]() to convert your object to a list of key-value pairs. This list can be filtered and transformed easily.",
      "to_entries[]\n| select(.value.auditScore == 1)?\n| [.value.onlineScore, .key]\n| join(\" \")",
      "jq -r 'to_entries[]\n| select(.value.auditScore == 1)?\n| \"Processing \\(.key)...\\nonlineScore is \\(.value.onlineScore)\"'"
    ],
    "utterance": "For each object where auditScore is 1, output the parent object name and the onlineScore.",
    "expressions": [
      "to_entries[] | select(.value.auditScore == 1)? | [.value.onlineScore, .key] | join(\" \")",
      "jq -r 'to_entries[] | select(.value.auditScore == 1)? | [ .value.onlineScore, .key ] | join(\" \")'",
      "jq -r 'to_entries[] | select(.value.auditScore == 1)? | \"Processing \\(.key)...\\nonlineScore is \\(.value.onlineScore)\"'"
    ],
    "data": [
      {
        "input": {
          "storageSummary": 68624392000000.0,
          "audit1": {
            "auditScore": 1,
            "suspensionScore": 1,
            "onlineScore": 0.99743587,
            "satelliteName": "us2.storj.io:7777"
          },
          "audit2": {
            "auditScore": 1,
            "suspensionScore": 1,
            "onlineScore": 0.9992917,
            "satelliteName": "saltlake.tardigrade.io:7777"
          },
          "audit3": {
            "auditScore": 1,
            "suspensionScore": 1,
            "onlineScore": 0.99930555,
            "satelliteName": "ap1.storj.io:7777"
          }
        },
        "output": [
          "0.99743587 audit1",
          "0.9992917 audit2",
          "0.99930555 audit3"
        ]
      }
    ],
    "identifier": 76261455
  },
  {
    "context": [
      "How do I modify the jq code in: \n\necho '{\"date\":\"20200101\"}{\"date\":\"20210101\"}' | jq -r '\"The bus will be here on \\( .date ), at ten o clock\"'\n\nto change the format of the date from eg `20200101` into `2020-01-01`?",
      "I want the output:\n\n    The bus will be here on 2020-01-01, at ten o clock\n    The bus will be here on 2021-01-01, at ten o clock",
      "In this case, you should simply slice the string:\n\necho '{\"date\":\"20200101\"}{\"date\":\"20210101\"}' | jq -r '\"The bus will be here on \\( .date | .[0:4] + \"-\" + .[4:6] + \"-\" + .[6:8] ), at ten o clock\"'",
      "You can also use `strptime` to first parse the `%Y%m%d`-formatted date, then re-format it with `strftime` to, for example, `%F`:\n\u2026 | jq -r '\"The bus will be here on \\(.date | strptime(\"%Y%m%d\") | strftime(\"%F\")), at ten o clock\"'"
    ],
    "utterance": "Format the date field from yyyymmdd to yyyy-mm-dd inside each message: 'The bus will be here on <date>, at ten o clock'.",
    "expressions": [
      ".date | .[0:4] + \"-\" + .[4:6] + \"-\" + .[6:8]",
      ".date | strptime(\"%Y%m%d\") | strftime(\"%F\")"
    ],
    "data": [
      {
        "input": [
          {
            "date": "20200101"
          },
          {
            "date": "20210101"
          }
        ],
        "output": [
          "The bus will be here on 2020-01-01, at ten o clock",
          "The bus will be here on 2021-01-01, at ten o clock"
        ]
      }
    ],
    "identifier": 76273350
  },
  {
    "context": [
      "I want to update the content (I'm storing the json into a variable, since I make several updates, then I'll create a new file), but the path of the data to update is variable :",
      "ds=\"audit1\";\nnew_name=\"toto\";",
      "jq --arg ds \"$ds\" --arg name \"$new_name\" '.[$ds][\"satelliteName\"] = $name' <<< \"$DS_OBJECT\";"
    ],
    "utterance": "Set the value of the satelliteName property for the object whose key is stored in the variable ds to the value of the variable new_name.",
    "expressions": [
      ".[$ds][\"satelliteName\"] = $name"
    ],
    "data": [
      {
        "input": {
          "storageSummary": 68624392000000.0,
          "audit1": {
            "auditScore": 1,
            "suspensionScore": 1,
            "onlineScore": 0.99743587,
            "satelliteName": "us2.storj.io:7777"
          },
          "audit2": {
            "auditScore": 1,
            "suspensionScore": 1,
            "onlineScore": 0.9992917,
            "satelliteName": "saltlake.tardigrade.io:7777"
          },
          "audit3": {
            "auditScore": 1,
            "suspensionScore": 1,
            "onlineScore": 0.99930555,
            "satelliteName": "ap1.storj.io:7777"
          }
        },
        "output": {
          "storageSummary": 68624392000000.0,
          "audit1": {
            "auditScore": 1,
            "suspensionScore": 1,
            "onlineScore": 0.99743587,
            "satelliteName": "toto"
          },
          "audit2": {
            "auditScore": 1,
            "suspensionScore": 1,
            "onlineScore": 0.9992917,
            "satelliteName": "saltlake.tardigrade.io:7777"
          },
          "audit3": {
            "auditScore": 1,
            "suspensionScore": 1,
            "onlineScore": 0.99930555,
            "satelliteName": "ap1.storj.io:7777"
          }
        }
      }
    ],
    "identifier": 76273403
  },
  {
    "context": [
      "I am working on code to check if only when user Jerry exists and has state APPROVED I should set a variable value as true else it should be false.",
      "You can have jq output `true` or `false`, thus set the variable directly. Within jq, you can use `any` to find \"at least one item\" that matches your criteria.",
      "hasJerry=\"$(jq 'any(.user.login == \"JERRY\" and .state == \"APPROVED\")' input.json)\""
    ],
    "utterance": "Check if there is at least one entry where the user's login is JERRY and the state is APPROVED.",
    "expressions": [
      "any(.user.login == \"JERRY\" and .state == \"APPROVED\")"
    ],
    "data": [
      {
        "input": [
          {
            "user": {
              "login": "TOM"
            },
            "body": "",
            "state": "APPROVED"
          },
          {
            "user": {
              "login": "JERRY"
            },
            "body": "",
            "state": "APPROVED"
          },
          {
            "user": {
              "login": "ANDY"
            },
            "body": "",
            "state": "REJECTED"
          }
        ],
        "output": true
      },
      {
        "input": [
          {
            "user": {
              "login": "TOM"
            },
            "body": "",
            "state": "APPROVED"
          },
          {
            "user": {
              "login": "JERRY"
            },
            "body": "",
            "state": "REJECTED"
          },
          {
            "user": {
              "login": "ANDY"
            },
            "body": "",
            "state": "REJECTED"
          }
        ],
        "output": false
      },
      {
        "input": [
          {
            "user": {
              "login": "TOM"
            },
            "body": "",
            "state": "APPROVED"
          },
          {
            "user": {
              "login": "ANDY"
            },
            "body": "",
            "state": "REJECTED"
          }
        ],
        "output": false
      }
    ],
    "identifier": 76289104
  },
  {
    "context": [
      "How to split the above response into 2 as below in shell script.",
      "Neither the input nor the desired output is valid JSON. Thus, treating input and output as raw text (using jq with flags `-Rr`, although at this point you could use any JSON-unrelated text-processing tool), you could simply scan by regular expressions, for instance from `{` to `}`:",
      "jq -Rr 'scan(\"({[^}]*})\")[]'"
    ],
    "utterance": "Extract each group of text between curly braces from a raw multiline string variable.",
    "expressions": [
      "jq -Rr 'scan(\"({[^}]*})\")[]'"
    ],
    "data": [
      {
        "input": "PROMETHEUS_METRIC: { __name__: sc_pcd_g2version, container: mgmtbroker, endpoint: vxexporter, instance: 10.42.24.132:9116, job: prometheus, namespace: delivery, pod: chn1-d1-ac-0, service: prometheus }{ __name__: sc_pcd_g2version, container: mgmtbroker, endpoint: vxexporter, instance: 10.42.3.110:9116, job: prometheus, namespace: delivery, pod: chn1-d1-ia-0, service: prometheus }",
        "output": [
          "{ __name__: sc_pcd_g2version, container: mgmtbroker, endpoint: vxexporter, instance: 10.42.24.132:9116, job: prometheus, namespace: delivery, pod: chn1-d1-ac-0, service: prometheus }",
          "{ __name__: sc_pcd_g2version, container: mgmtbroker, endpoint: vxexporter, instance: 10.42.3.110:9116, job: prometheus, namespace: delivery, pod: chn1-d1-ia-0, service: prometheus }"
        ]
      }
    ],
    "identifier": 76292146
  },
  {
    "context": [
      "I have a file that contains this format:\r\n\r\n```\r\nCus Id: 1234\r\nCus Name: 10:/John Parks\r\nCus Type: temporary\r\nCus client: tesla;toyota\r\nDept Id: 111\r\n\r\nCus Id: 1235\r\nCus Name: 10:/William Parks\r\nCus Type: temporary\r\nCus client:\r\nDept Id: 222\r\n```\r\nHow can I convert this to JSON format? Any methods bash, jq, or python is fine.",
      "jq -Rs '                        # 1. -Rs = read the input into a single string\r\n    split(\"\\n{2,}\", \"\")         # 2. split on sequences of blank lines\r\n    | map(                      # 3. transform each paragraph into an object\r\n        split(\"\\n\") \r\n        | map(scan(\"^([^:]+)(: (.*))?\") | {key: first, value: last}) \r\n        | from_entries\r\n    )\n' data.file",
      "outputs\n```\n[\n  {\n    \"Cus Id\": \"1234\",\n    \"Cus Name\": \"10:/John Parks\",\n    \"Cus Type\": \"temporary\",\n    \"Cus client\": \"tesla;toyota\",\n    \"Dept Id\": \"111\"\n  },\n  {\n    \"Cus Id\": \"1235\",\n    \"Cus Name\": \"10:/William Parks\",\n    \"Cus Type\": \"temporary\",\n    \"Cus client\": null,\n    \"Dept Id\": \"222\"\n  }\n]",
      "jq -Rn 'reduce (inputs | capture(\"(?<k>[^:]+):\\\\s*(?<v>.*)|\")) as $in (\n  [{}]; if $in.k then last[$in.k] = $in.v else . + [{}] end\n)'"
    ],
    "utterance": "Convert blocks of colon-separated key-value pairs separated by blank lines into an array of objects, preserving empty values as null or empty strings.",
    "expressions": [
      "jq -Rs 'split(\"\\n{2,}\") | map(split(\"\\n\") | map(scan(\"^([^:]+)(: (.*))?\") | {key: .[0], value: .[2]}) | from_entries)'",
      "jq -Rn 'reduce (inputs | capture(\"(?<k>[^:]+):\\s*(?<v>.*)|\")) as $in ([{}]; if $in.k then last[$in.k] = $in.v else . + [{}] end)'"
    ],
    "data": [
      {
        "input": "Cus Id: 1234\nCus Name: 10:/John Parks\nCus Type: temporary\nCus client: tesla;toyota\nDept Id: 111\n\nCus Id: 1235\nCus Name: 10:/William Parks\nCus Type: temporary\nCus client:\nDept Id: 222\n",
        "output": [
          {
            "Cus Id": "1234",
            "Cus Name": "10:/John Parks",
            "Cus Type": "temporary",
            "Cus client": "tesla;toyota",
            "Dept Id": "111"
          },
          {
            "Cus Id": "1235",
            "Cus Name": "10:/William Parks",
            "Cus Type": "temporary",
            "Cus client": null,
            "Dept Id": "222"
          }
        ]
      }
    ],
    "identifier": 76283081
  },
  {
    "context": [
      "What I want to do is use `jq` scripting to select all elements that contain slot with a certain value and save them in a separate json file, let's call it `data_for_slot.json`",
      "Let's assume I want all elements where `slot = 6436990`. For this purpose, I used:\n\n```\njq -c '[select(.data.slot == \"6436990\")]' data.json > data_for_slot.json\n```",
      "The jq filter `[select(.data.slot == \"6436990\")]` will create an array `[\u2026]` for each input item. As you are filtering out (most of) the input items using `select(\u2026)`, you get a stream of (mostly) empty arrays.\n\nDrop the array brackets (just use `select(\u2026)`) and there will be no output for input items not matching."
    ],
    "utterance": "Extract all objects where the property data.slot is equal to \"6436990\".",
    "expressions": [
      "select(.data.slot == \"6436990\")"
    ],
    "data": [
      {
        "input": {
          "aggregation_bits": "0xf7fffffffffffdfffffffffffffdfffffffffffffffffffffff7fffffffffffffff7ff",
          "data": {
            "slot": "6436981",
            "index": "8",
            "beacon_block_root": "0xf8afce2fc26df10061d641633a7256cf47ffa8793771ae83e190e72bf2c5886e",
            "source": {
              "epoch": "201154",
              "root": "0x694231a8135b3f546a6fe483ba6b467c686592f6d627aaf06b56ffbd78d75f63"
            },
            "target": {
              "epoch": "201155",
              "root": "0x2fc0d9f58cda026678d98f010fec13d202eec4ec9ae4dbd57878413a75fe22d7"
            }
          },
          "signature": "0xadb0d576ee418e37017f423e77622ce85bdb741d0e984e78df3a250c172fc67c6c7ec94e4802d6323aee8f62b7df218300f42010fe673ed85f4e06d1361336474ecfb4db39aa2bc31b31bf6fbe52c7bff769f024faa5ba3554d5ea02fe9663c3",
          "arrival": 1684067808365
        }
      }
    ],
    "identifier": 76295204
  },
  {
    "context": [
      "curl -c - \"https://sample.com\" -H 'User-Agent: Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:109.0) Gecko/20100101 Firefox/110.0' -H 'Accept: application/json, text/plain, */*' -s | jq .data.name.status",
      "jq .data.name.status data.txt"
    ],
    "utterance": "Extract the status field from the name property inside the data object of the response.",
    "expressions": [
      ".data.name.status"
    ],
    "identifier": 76307599
  },
  {
    "context": [
      "I have JSON file with below format\n\n    {\n        \"key1\": [\"val1\", \"val2\"],\n        \"key2\": [\"v1\", \"v2\"]\n    }\n\nI want to transform it into\n \n\n    {\n        \"key1\": [\"val1-v1\", \"val2-v2\"],\n        \"key2\": [\"v1\", \"v2\"]\n    }\n\nHow can I acheive this using jq in linux environment?",
      "You could use `to_entries` to generate an array of indices and values. Use the indices to index into the other key, stored in a variable for reference:\n```sh\njq '. as {$key2} | .key1 |= [to_entries[] | .value + \"-\" + $key2[.key]]' data.json\n```",
      "If the arrays aren't big, you could also use the less efficient `transpose` filter to zip them:\n```sh\njq '.key1 = [map(.) | transpose[] | join(\"-\")]' data.json\n```",
      "Output of both:\n```json\n{\n  \"key1\": [\n    \"val1-v1\",\n    \"val2-v2\"\n  ],\n  \"key2\": [\n    \"v1\",\n    \"v2\"\n  ]\n}\n```"
    ],
    "utterance": "Combine corresponding elements of key1 and key2 using a hyphen as separator, and assign the result back to key1 while keeping key2 unchanged.",
    "expressions": [
      ". as {$key2} | .key1 |= [to_entries[] | .value + \"-\" + $key2[.key]]",
      ".key1 = [map(.) | transpose[] | join(\"-\")]"
    ],
    "data": [
      {
        "input": {
          "key1": [
            "val1",
            "val2"
          ],
          "key2": [
            "v1",
            "v2"
          ]
        },
        "output": {
          "key1": [
            "val1-v1",
            "val2-v2"
          ],
          "key2": [
            "v1",
            "v2"
          ]
        }
      }
    ],
    "identifier": 76298165
  },
  {
    "context": [
      "I am trying to figure out the location stuff so I can get the package name and its version.",
      "I am also trying to get the identifiers information.",
      "Now, if you want CSV, it is easier to use the builtin `@csv` filter. You don't need that `echo` for the headers either, `jq` can add the headers just fine:",
      "[\"id\", \"message\", \"description\", \"severity\", \"name\", \"version\", \"identifiers\"],",
      "    .vulnerabilities[]",
      "    | [",
      "      .id,",
      "      .message,",
      "      .description,",
      "      .severity,",
      "      (.location.dependency | .package.name, .version),",
      "      (.identifiers[0] | .type, .name, .value, .url)",
      "    ]",
      "| @csv"
    ],
    "utterance": "Extract id, message, description, severity, package name, version, and first identifier's type, name, value, and url from each vulnerability and output as CSV.",
    "expressions": [
      "[\"id\", \"message\", \"description\", \"severity\", \"name\", \"version\", \"type\", \"identifier_name\", \"identifier_value\", \"identifier_url\"], (.vulnerabilities[] | [ .id, .message, .description, .severity, .location.dependency.package.name, .location.dependency.version, (.identifiers[0] | .type, .name, .value, .url) ]) | @csv"
    ],
    "data": [
      {
        "input": {
          "vulnerabilities": [
            {
              "id": "CVE-2015-5186",
              "category": "container_scanning",
              "message": "Audit: log terminal emulator escape sequences handling",
              "description": "Audit before 2.4.4 in Linux does not sanitize escape characters in filenames.",
              "cve": "CVE-2015-5186",
              "severity": "Medium",
              "solution": "No solution provided",
              "scanner": {
                "id": "trivy",
                "name": "trivy"
              },
              "location": {
                "dependency": {
                  "package": {
                    "name": "audit-libs"
                  },
                  "version": "2.8.5-4.el7"
                },
                "operating_system": "Unknown",
                "image": "image.tar"
              },
              "identifiers": [
                {
                  "type": "cve",
                  "name": "CVE-2015-5186",
                  "value": "CVE-2015-5186",
                  "url": "example.com"
                }
              ],
              "links": [
                {
                  "url": "example.com"
                }
              ]
            }
          ]
        },
        "output": "\"id\",\"message\",\"description\",\"severity\",\"name\",\"version\",\"type\",\"identifier_name\",\"identifier_value\",\"identifier_url\"\n\"CVE-2015-5186\",\"Audit: log terminal emulator escape sequences handling\",\"Audit before 2.4.4 in Linux does not sanitize escape characters in filenames.\",\"Medium\",\"audit-libs\",\"2.8.5-4.el7\",\"cve\",\"CVE-2015-5186\",\"CVE-2015-5186\",\"example.com\""
      }
    ],
    "identifier": 76240669
  },
  {
    "context": [
      "How can I get a consolidation (fusion) of those such as :",
      "Here is one way:",
      "jq -s 'add | group_by(.lang) | map(add)' file1.json file2.json",
      "and another:",
      "jq -n 'reduce inputs[] as $obj ({};\n  .[$obj.lang] += $obj\n) | map(.)' file1.json file2.json"
    ],
    "utterance": "Merge two arrays of objects from separate files by matching on the 'lang' property, combining all fields from matching objects into one object for each 'lang'.",
    "expressions": [
      "jq -s 'add | group_by(.lang) | map(add)' file1.json file2.json",
      "jq -n 'reduce inputs[] as $obj ({}; .[$obj.lang] += $obj) | map(.)' file1.json file2.json"
    ],
    "data": [
      {
        "input": [
          [
            {
              "lang": "Inari Sami",
              "audios": 78
            },
            {
              "lang": "Tofalar",
              "audios": 42
            },
            {
              "lang": "Kumyk",
              "audios": 305
            }
          ],
          [
            {
              "lang": "Inari Sami",
              "isoCode": "smn",
              "genderFemales": 1,
              "genderMales": 5,
              "genderOthers": 3
            },
            {
              "lang": "Tofalar",
              "genderFemales": 2,
              "genderMales": 3,
              "genderOthers": 1
            },
            {
              "lang": "Kumyk",
              "isoCode": "kum",
              "genderFemales": 5,
              "genderMales": 4,
              "genderOthers": 2
            },
            {
              "lang": "French"
            }
          ]
        ],
        "output": [
          {
            "lang": "Inari Sami",
            "audios": 78,
            "isoCode": "smn",
            "genderFemales": 1,
            "genderMales": 5,
            "genderOthers": 3
          },
          {
            "lang": "Tofalar",
            "audios": 42,
            "genderFemales": 2,
            "genderMales": 3,
            "genderOthers": 1
          },
          {
            "lang": "Kumyk",
            "audios": 305,
            "isoCode": "kum",
            "genderFemales": 5,
            "genderMales": 4,
            "genderOthers": 2
          },
          {
            "lang": "French"
          }
        ]
      }
    ],
    "identifier": 76299813
  },
  {
    "context": [
      "I would like to filter it so that I get an array with items that have `field2` set to `true` and then get its length (so in the example it would return 3 of the 4 items)",
      "jq '.Obj | map(select(.field2 == true))' <<< \"$obj\"",
      ".Obj | map(select(.field2 == true)) | ., length"
    ],
    "utterance": "Select all objects where field2 is true and output the filtered array and its length.",
    "expressions": [
      ".Obj | map(select(.field2 == true))",
      ".Obj | map(select(.field2 == true)) | ., length"
    ],
    "data": [
      {
        "input": {
          "Obj": [
            {
              "field1": "a",
              "field2": true
            },
            {
              "field1": "b",
              "field2": true
            },
            {
              "field1": "c",
              "field2": false
            },
            {
              "field1": "d",
              "field2": true
            }
          ]
        },
        "output": [
          [
            {
              "field1": "a",
              "field2": true
            },
            {
              "field1": "b",
              "field2": true
            },
            {
              "field1": "d",
              "field2": true
            }
          ],
          3
        ]
      }
    ],
    "identifier": 76316881
  },
  {
    "context": [
      "i wish to \"sort\" the second file using the first one as a \"model\", basically moving all the fields to match the position in the first one.",
      "Assuming we have only to deal with top-level keys, the following approach would suffice.",
      "< input.json | jq --argfile reference reference.json '\n  . as $in\n  | ($reference|keys_unsorted) as $refkeys\n  | (keys_unsorted - $refkeys) as $remainder\n  | reduce ($refkeys[], $remainder[]) as $k ({};\n      if $in|has($k) then .[$k] = $in[$k] else . end)\n'"
    ],
    "utterance": "Reorder the top-level fields of one object to match the order of fields in another object, with any extra fields appended in their original order.",
    "expressions": [
      ". as $in | ($reference|keys_unsorted) as $refkeys | (keys_unsorted - $refkeys) as $remainder | reduce ($refkeys[], $remainder[]) as $k ({}; if $in|has($k) then .[$k] = $in[$k] else . end)"
    ],
    "data": [
      {
        "input": {
          "input.json": {
            "b": 1,
            "a": 2,
            "x": 3
          },
          "reference.json": {
            "a": 10,
            "b": 20,
            "y": 30
          }
        },
        "output": {
          "a": 2,
          "b": 1,
          "x": 3
        }
      }
    ],
    "identifier": 76312374
  },
  {
    "context": [
      "I need (that should be quite simple though...) to update the `auditScore` when `satelliteName` is `us2.storj.io:7777`",
      "Use [`with_entries`][1] to be able to [`select()`][2] the object where your condition match.",
      "Then update the `.value.auditScore` to something new:\r\n\r\n```\r\nwith_entries(select(.value?.satelliteName? == \"us2.storj.io:7777\").value.auditScore = 999)\r\n```",
      ".[]|select(.satelliteName==\"us2.storj.io:7777\") : it only works if I remove the 1st entry in my dataset : \"storageSummary\": 68624392000000, otherwise, I get jq: error (at <stdin>:20): Cannot index number with string \"satelliteName\""
    ],
    "utterance": "Set auditScore to 999 for the object whose satelliteName is us2.storj.io:7777",
    "expressions": [
      "with_entries(if .value?.satelliteName? == \"us2.storj.io:7777\" then .value.auditScore = 999 | . else . end)"
    ],
    "data": [
      {
        "input": {
          "storageSummary": 68624392000000,
          "audit1": {
            "auditScore": 1,
            "suspensionScore": 1,
            "onlineScore": 0.99743587,
            "satelliteName": "us2.storj.io:7777"
          },
          "audit2": {
            "auditScore": 1,
            "suspensionScore": 1,
            "onlineScore": 0.9992917,
            "satelliteName": "saltlake.tardigrade.io:7777"
          },
          "audit3": {
            "auditScore": 1,
            "suspensionScore": 1,
            "onlineScore": 0.99930555,
            "satelliteName": "ap1.storj.io:7777"
          }
        },
        "output": {
          "storageSummary": 68624392000000,
          "audit1": {
            "auditScore": 999,
            "suspensionScore": 1,
            "onlineScore": 0.99743587,
            "satelliteName": "us2.storj.io:7777"
          },
          "audit2": {
            "auditScore": 1,
            "suspensionScore": 1,
            "onlineScore": 0.9992917,
            "satelliteName": "saltlake.tardigrade.io:7777"
          },
          "audit3": {
            "auditScore": 1,
            "suspensionScore": 1,
            "onlineScore": 0.99930555,
            "satelliteName": "ap1.storj.io:7777"
          }
        }
      }
    ],
    "identifier": 76315906
  },
  {
    "context": [
      "What I would like to obtain is a map of lists of strings which would have as key the first two words of the string from the list and as value the strings that starts with that specific key.",
      "I'm expecting:",
      "{\r\n  \"nonprod/global\":[\r\n    \"nonprod/global/app/sit01\",\r\n    \"nonprod/global/app/dev02\",\r\n    \"nonprod/global/app/dev03\"\r\n  ],\r\n  \"prod/eu\":[\r\n    \"prod/eu/app/prod01\"\r\n  ],\r\n  \r\n  \"prod/na\":[\r\n    \"prod/na/app/prod01\"\r\n  ],\r\n  \"test/eu\":[\r\n    \"test/eu/app/cust01\"\r\n  ]\r\n}",
      "You can define a function that splits at the second slash, then use it to group_by the input array, creating an array of arrays, then use INDEX to turn it into an object, using the same function on the first item.",
      "Use += to add to an array. If the key doesn't exist, jq will create it on the fly (null + [] evaluates to []):"
    ],
    "utterance": "Group the list by the first two path segments and create an object where each key is those segments and its value is a list of all original strings that start with them.",
    "expressions": [
      "def f: .[:indices(\"/\")[1]]; group_by(f) | INDEX(first | f)",
      "reduce (.[] | capture(\"^(?<env>(?<type>[^/]*/[^/]*).*)$\") ) as {$env, $type} ({}; .[$type] += [$env])"
    ],
    "data": [
      {
        "input": [
          "nonprod/global/app/sit01",
          "nonprod/global/app/dev02",
          "prod/na/app/prod01",
          "test/eu/app/cust01",
          "nonprod/global/app/dev03"
        ],
        "output": {
          "nonprod/global": [
            "nonprod/global/app/sit01",
            "nonprod/global/app/dev02",
            "nonprod/global/app/dev03"
          ],
          "prod/na": [
            "prod/na/app/prod01"
          ],
          "test/eu": [
            "test/eu/app/cust01"
          ]
        }
      }
    ],
    "identifier": 76308296
  },
  {
    "identifier": 76333390
  },
  {
    "context": [
      "The OP mentioned in the title of his post and in a comment that the output shall be a dictionary (and not an array of strings). I.e. a list of **key value pairs**",
      "shall be converted  to a **dictionary**",
      "This is achieved via",
      "jq \"map({(.name): .status}) | add\""
    ],
    "utterance": "Convert an array of objects with name and status fields to an object that maps each name to its status value.",
    "expressions": [
      "map({(.name): .status}) | add"
    ],
    "data": [
      {
        "input": [
          {
            "name": "plugin",
            "status": "Started"
          },
          {
            "name": "c_docker_2",
            "status": "Started"
          },
          {
            "name": "c_docker_5",
            "status": "Started"
          },
          {
            "name": "c_docker_4",
            "status": "Started"
          },
          {
            "name": "c_docker_3",
            "status": "Started"
          },
          {
            "name": "c_docker_1",
            "status": "Started"
          }
        ],
        "output": {
          "plugin": "Started",
          "c_docker_2": "Started",
          "c_docker_5": "Started",
          "c_docker_4": "Started",
          "c_docker_3": "Started",
          "c_docker_1": "Started"
        }
      }
    ],
    "identifier": 76331173
  },
  {
    "context": [
      "I'd like to drop all objects in the top-level object which have `\"cycle == null\"`.",
      "I'd like to keep the structure of the matching entries, something like this:",
      "`jq '.[] |= (.[] |= select(.cycle != null) | select(. != {}))'`"
    ],
    "utterance": "Keep only entries whose immediate children have a non-null 'cycle' property, preserving the nested structure and removing empty objects.",
    "expressions": [
      ".[] |= (.[] |= select(.cycle != null) | select(. != {}))"
    ],
    "data": [
      {
        "input": {
          "foo": {},
          "bar": {
            "a": {
              "tags": [
                "x",
                "y"
              ],
              "cycle": "simple"
            },
            "b": {
              "tags": [
                "x"
              ],
              "cycle": null
            }
          },
          "baz": {
            "c": {
              "tags": [
                "y"
              ],
              "cycle": null
            }
          },
          "qux": {
            "d": {
              "tags": [
                "x",
                "y",
                "z"
              ],
              "cycle": "complex"
            }
          }
        },
        "output": {
          "bar": {
            "a": {
              "tags": [
                "x",
                "y"
              ],
              "cycle": "simple"
            }
          },
          "qux": {
            "d": {
              "tags": [
                "x",
                "y",
                "z"
              ],
              "cycle": "complex"
            }
          }
        }
      }
    ],
    "identifier": 76332247
  },
  {
    "context": [
      "How can I use [jq](https://stedolan.github.io/jq/) to sort an array of objects by an IPv4 address value as a 32-bit integer rather than alphanumerically?",
      "This `|=sort_by(.ip)` sorts in alphanumeric order, but I'd like the array sorted \"IPnumerically\".",
      "You can simply split the ip and convert it to an array of numbers:",
      "sort_by(.ip | split(\".\")[] | tonumber)"
    ],
    "utterance": "Sort an array of objects by the ip field so that the order reflects numerical IPv4 address order rather than alphanumeric order.",
    "expressions": [
      "sort_by(.ip | split(\".\")[] | tonumber)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "dns",
            "ip": "4.4.4.4"
          },
          {
            "name": "host1",
            "ip": "10.9.9.9"
          },
          {
            "name": "host2",
            "ip": "10.10.10.10"
          }
        ],
        "output": [
          {
            "name": "dns",
            "ip": "4.4.4.4"
          },
          {
            "name": "host1",
            "ip": "10.9.9.9"
          },
          {
            "name": "host2",
            "ip": "10.10.10.10"
          }
        ]
      }
    ],
    "identifier": 76343829
  },
  {
    "context": [
      "There are two block below how to iterate the below data block using jq filter which should pick on first iteration\n{ __name__: sc_pcd_g2version, container: mgmtbroker, endpoint: vxexporter, instance: 10.42.24.132:9116, job: prometheus, namespace: delivery, pod: chn1-d1-ac-0, service: prometheus }",
      "On second iteration, it should pick the second one",
      "The quasi-JSON to JSON step could be accomplished as follows:\n```\njq -R '\n  def rtrim: sub(\" +$\";\"\");\n  def kvs:\n     capture( \", ]*(?<key>[^:]+) *: *(?<value>[^,]*)(?<etc>.*)\" )\n     | {key,value}, (.etc | kvs) ;\n\n  scan( \" *[{] *([^}]+)[}]\" ) | first | rtrim | [kvs] | from_entries\n'\n```",
      "With your sample input, this produces:\n{\n  \"__name__\": \"sc_pcd_g2version\",\n  ...\n}\n{\n  \"__name__\": \"sc_pcd_g2version\",\n  ...\n}"
    ],
    "utterance": "Extract each top-level block delimited by curly braces from the input, treating each as a separate object for iteration.",
    "expressions": [
      "jq -R '\n  def rtrim: sub(\" +$\";\"\");\n  def kvs:\n     capture(\", ]*(?<key>[^:]+) *: *(?<value>[^,]*)(?<etc>.*)\")\n     | {key,value}, (.etc | kvs) ;\n  scan(\" *[{] *([^}]+)[}]\") | map(rtrim | [kvs] | from_entries)\n'"
    ],
    "data": [
      {
        "input": "{ __name__: sc_pcd_g2version, container: mgmtbroker, endpoint: vxexporter, instance: 10.42.24.132:9116, job: prometheus, namespace: delivery, pod: chn1-d1-ac-0, service: prometheus }\n{ __name__: sc_pcd_g2version, container: mgmtbroker, endpoint: vxexporter, instance: 10.42.3.110:9116, job: prometheus, namespace: delivery, pod: chn1-d1-ia-0, service: prometheus }",
        "output": [
          {
            "__name__": "sc_pcd_g2version",
            "container": "mgmtbroker",
            "endpoint": "vxexporter",
            "instance": "10.42.24.132:9116",
            "job": "prometheus",
            "namespace": "delivery",
            "pod": "chn1-d1-ac-0",
            "service": "prometheus"
          },
          {
            "__name__": "sc_pcd_g2version",
            "container": "mgmtbroker",
            "endpoint": "vxexporter",
            "instance": "10.42.3.110:9116",
            "job": "prometheus",
            "namespace": "delivery",
            "pod": "chn1-d1-ia-0",
            "service": "prometheus"
          }
        ]
      }
    ],
    "identifier": 76296125
  },
  {
    "context": [
      "I would like to merge these Files based on it's IDs resulting to:\n```\n{\"test\":{\"a\":2,\"b\":3,\"c\":8},\"id\":\"850303847\"}\n{\"test\":{\"a\":3,\"b\":3,\"c\":4},\"id\":\"2742540872\"}\n{\"test\":{\"a\":4,\"b\":4,\"c\":5},\"id\":\"1358887220\"}\n```",
      "You could `reduce` all `inputs` into an object with `.id` as key, deep-merge using `*`, then iterate over the fields `.[]` to obtain a stream again (use the `-c` flag for compact output):\n```sh\njq -nc 'reduce inputs as $i ({}; .[$i.id] |= (. // {}) * $i) | .[]' file*.json\n```",
      "Here is one way:\n``` sh\njq -nc '\nreduce inputs as {$test, $id} ({};\n  .[$id] += $test\n)\n| keys_unsorted[] as $id\n| {test: .[$id], $id}' files...\n```"
    ],
    "utterance": "Merge multiple files by matching id; for each id, combine all test fields so the result for each id has all keys from test merged together.",
    "expressions": [
      "jq -nc 'reduce inputs as $i ({}; .[$i.id] |= (. // {}) * $i) | .[]' file*.json",
      "jq -nc '\nreduce inputs as {$test, $id} ({};\n  .[$id] += $test\n)\n| keys_unsorted[] as $id\n| {test: .[$id], $id}' files..."
    ],
    "data": [
      {
        "input": [
          "{\"test\":{\"a\":2},\"id\":\"850303847\"}",
          "{\"test\":{\"a\":3},\"id\":\"2742540872\"}",
          "{\"test\":{\"a\":4},\"id\":\"1358887220\"}"
        ],
        "output": [
          "{\"test\":{\"a\":2,\"b\":3,\"c\":8},\"id\":\"850303847\"}",
          "{\"test\":{\"a\":3,\"b\":3,\"c\":4},\"id\":\"2742540872\"}",
          "{\"test\":{\"a\":4,\"b\":4,\"c\":5},\"id\":\"1358887220\"}"
        ]
      },
      {
        "input": [
          "{\"test\":{\"b\":3},\"id\":\"850303847\"}",
          "{\"test\":{\"b\":3},\"id\":\"2742540872\"}",
          "{\"test\":{\"b\":4},\"id\":\"1358887220\"}"
        ]
      },
      {
        "input": [
          "{\"test\":{\"c\":8},\"id\":\"850303847\"}",
          "{\"test\":{\"c\":4},\"id\":\"2742540872\"}",
          "{\"test\":{\"c\":5},\"id\":\"1358887220\"}"
        ]
      }
    ],
    "identifier": 76350965
  },
  {
    "context": [
      "isn't it possible to use jq do actually take the order of the keys in input.json and apply that to output.json?",
      "With the current implementation of jq (meaning: this \"side-effect\" is not documented, it may change without notice), you could predetermine the order of the keys by successively building up your output object. To this end, you would iterate over the input object's keys in the order they are read using `keys_unsorted`, and set them in the output object, starting out with the empty object `{}`:\n```sh\njq 'input as $in | reduce keys_unsorted[] as $key ({}; .[$key] = $in[$key])' \\\n  input.json output.json > reordered_output.json\n```\n(Note that, confusingly, the second input file, here `output.json`, is referenced by the `input` filter.)",
      "Edit: ... While sample data is missing, let's consider all objects as nodes, and every other data type as leafs. In order to access both keys and values, change `keys_unsorted` to `to_entries` ... and elevate the logic into a named filter (function definition), so that it can be called recursively on `objects`.\n```sh\ndef reorder($in; $ref): $ref | reduce to_entries[] as {$key, $value} ({};\n  .[$key] = ($in[$key] | objects |= reorder(.; $value))\n);\nreorder(input; .)\n```"
    ],
    "utterance": "Order all keys in one file according to the order of keys in another file, recursively for nested objects.",
    "expressions": [
      "input as $in | reduce keys_unsorted[] as $key ({}; .[$key] = $in[$key])",
      "def reorder($in; $ref): $ref | reduce to_entries[] as {$key, $value} ({};\n  .[$key] = ($in[$key] | objects |= reorder(.; $value))\n);\nreorder(input; .)"
    ],
    "data": [
      {
        "input": {
          "input.json": {
            "BathroomType": "Type of bathroom",
            "BuildingType": "Type of building",
            "enums": {
              "OrientationGarden": {
                "EAST": "East",
                "SOUTH": "South",
                "NORTH": "North",
                "WEST": "West"
              },
              "TerrainRecentDestination": {
                "EXTRACTION": "extraction",
                "PARK": "park"
              }
            }
          },
          "output.json": {
            "BathroomType": "Type of bathroom2",
            "enums": {
              "TerrainRecentDestination": {
                "EXTRACTION": "extraction",
                "PARK": "park"
              },
              "OrientationGarden": {
                "SOUTH": "South",
                "EAST": "East2",
                "NORTH": "North",
                "WEST": "West"
              }
            },
            "BuildingType": "Type of building"
          }
        }
      }
    ],
    "identifier": 76362983
  },
  {
    "context": [
      "I am trying to export a very large JSON file (zip compressed: [full_ip-port.json][1]) to CSV.",
      "The file consists of a single JSON object that has a regular structure...",
      "How can I bring it together to a nice and clean CSV file?",
      "Since your example is sufficiently uniform, you could get away with:\n```\njq -r '\n  to_entries\n  | (.[0].value[0]|keys_unsorted) as $keys\n  | .[]\n  | .key as $key\n  | .value[]\n  | [$key, .[$keys[]] ]\n  | @csv\n'\n```",
      "You could also use [\"key\"] + $keys (for example) to produce a CVS header:\n```\nto_entries\n| (.[0].value[0]|keys_unsorted) as $keys\n| [\"key\"] + $keys,\n  (.[]\n   | .key as $key\n   | .value[]\n  | [$key, .[$keys[]] ])\n| @csv\n```"
    ],
    "utterance": "Extract all entries, including the top-level object key as a column, and output their field values as CSV, optionally including a header row.",
    "expressions": [
      "to_entries\n| (.[0].value[0]|keys_unsorted) as $keys\n| .[]\n| .key as $key\n| .value[]\n| [$key, .[$keys[]] ]\n| @csv",
      "to_entries\n| (.[0].value[0]|keys_unsorted) as $keys\n| [\"key\"] + $keys,\n  (.[]\n   | .key as $key\n   | .value[]\n  | [$key, .[$keys[]] ])\n| @csv"
    ],
    "data": [
      {
        "input": {
          "1122595": [
            {
              "ioc_value": "103.100.159.212:443",
              "ioc_type": "ip:port",
              "threat_type": "botnet_cc",
              "malware": "win.cobalt_strike",
              "malware_alias": "Agentemis,BEACON,CobaltStrike,cobeacon",
              "malware_printable": "Cobalt Strike",
              "first_seen_utc": "2023-05-27 02:31:39",
              "last_seen_utc": null,
              "confidence_level": 100,
              "reference": null,
              "tags": "CLOUDIE-AS-AP Cloudie Limited,CobaltStrike,cs-watermark-666666",
              "anonymous": "0",
              "reporter": "drb_ra"
            }
          ],
          "1122593": [
            {
              "ioc_value": "167.172.72.193:23",
              "ioc_type": "ip:port",
              "threat_type": "botnet_cc",
              "malware": "elf.bashlite",
              "malware_alias": "gayfgt,Gafgyt,qbot,torlus,lizkebab",
              "malware_printable": "Bashlite",
              "first_seen_utc": "2023-05-27 01:40:04",
              "last_seen_utc": null,
              "confidence_level": 75,
              "reference": "https://bazaar.abuse.ch/sample/6c901ba15327da68159712a9726807fb08868309726c55ef202818bfde22a5a7/",
              "tags": "Gafgyt",
              "anonymous": "0",
              "reporter": "abuse_ch"
            }
          ]
        },
        "output": [
          "\"1122595\",\"103.100.159.212:443\",\"ip:port\",\"botnet_cc\",\"win.cobalt_strike\",\"Agentemis,BEACON,CobaltStrike,cobeacon\",\"Cobalt Strike\",\"2023-05-27 02:31:39\",,100,,\"CLOUDIE-AS-AP Cloudie Limited,CobaltStrike,cs-watermark-666666\",\"0\",\"drb_ra\"",
          "\"1122593\",\"167.172.72.193:23\",\"ip:port\",\"botnet_cc\",\"elf.bashlite\",\"gayfgt,Gafgyt,qbot,torlus,lizkebab\",\"Bashlite\",\"2023-05-27 01:40:04\",,75,\"https://bazaar.abuse.ch/sample/6c901ba15327da68159712a9726807fb08868309726c55ef202818bfde22a5a7/\",\"Gafgyt\",\"0\",\"abuse_ch\""
        ]
      }
    ],
    "identifier": 76345607
  },
  {
    "context": [
      "$ jq -c --null-input --argjson options '[ { \"a\": \"b\" } ]' '$options += [ { \"c\": \"d\" } ] | $options'",
      "jq: error (at <unknown>): Invalid path expression with result [{\"a\":\"b\"}]",
      "The left-hand side of an assignment operator must refers to a value inside of `.`.",
      "A variable assignment is done using `... as $var | ...`.",
      "( $options + [ { \"c\": \"d\" } ] ) as $options | $options",
      "That said, there's no reason to change `$options` here. The following would do:",
      "$options + [ { \"c\": \"d\" } ]"
    ],
    "utterance": "Combine the list from the variable 'options' with an additional object { \"c\": \"d\" } and produce the resulting list.",
    "expressions": [
      "$options + [ { \"c\": \"d\" } ]",
      "($options + [ { \"c\": \"d\" } ]) as $options | $options"
    ],
    "data": [
      {
        "input": [
          {
            "a": "b"
          }
        ],
        "output": [
          {
            "a": "b"
          },
          {
            "c": "d"
          }
        ]
      }
    ],
    "identifier": 76372575
  },
  {
    "context": [
      "How to make sure all numbers are converted back to numbers ? (without corrupting rightful strings)",
      "You could `walk` through the document tree, and `if` you encounter a string `type`, try to convert it `tonumber`. If it fails (`?`), leave it as it was (`// .`). Likewise, if it wasn\u2019t a string in the first place (`else .`).",
      "walk(if type == \"string\" then tonumber? // . else . end)"
    ],
    "utterance": "Convert all string values that represent numbers to numbers, without changing non-numeric strings.",
    "expressions": [
      "walk(if type == \"string\" then tonumber? // . else . end)"
    ],
    "data": [
      {
        "input": [
          {
            "firstName": "Charles",
            "lastName": "Doe",
            "age": "65",
            "postalCode": "943",
            "habitants": "5"
          },
          {
            "firstName": "Charles",
            "lastName": "Doe",
            "age": 41,
            "postalCode": "94103",
            "habitants": "2"
          },
          {
            "firstName": "Charles",
            "lastName": "Doe",
            "age": 23,
            "postalCode": "94103",
            "habitants": "3",
            "animals": "1"
          }
        ],
        "output": [
          {
            "firstName": "Charles",
            "lastName": "Doe",
            "age": 65,
            "postalCode": 943,
            "habitants": 5
          },
          {
            "firstName": "Charles",
            "lastName": "Doe",
            "age": 41,
            "postalCode": 94103,
            "habitants": 2
          },
          {
            "firstName": "Charles",
            "lastName": "Doe",
            "age": 23,
            "postalCode": 94103,
            "habitants": 3,
            "animals": 1
          }
        ]
      }
    ],
    "identifier": 76397168
  },
  {
    "context": [
      "I have a json file that I need to convert in the following format preferably using Linux CLI tools. Is JQ a vehicle for that?",
      "# JSON FILE",
      "{\n\"30814\": {\n    \"uid\":       \"Joe.Jones\",\n    \"date\":       \"2023-05-02\",\n    \"reg\":       \"7.13\",\n    \"ot\":       \"0.00\"\n}, ... }",
      "# EXPECTED OUTPUT",
      "<table border=1>\n<tr>\n <td> NA\n <td> 2023-05-01 <td> 2023-05-02 <td> 2023-05-03\n<tr>\n  <td> Joe.Jones\n  <td> -  <td> 7.13/0.00  <td> 7.48/0.00\n<tr>\n  <td> Hank.Jones\n  <td> - <td> 6.37/0.00 <td> -\n<tr>\n  <td> Some.User\n  <td> 5.82/0.00 <td> 7.28/0.00 <td> -\n</table>",
      "Except for the ordering of the data rows, here&#39;s an all-jq solution:",
      "jq -r '\n\ndef tocell:\n  \"<td>\\(.)</td>\";\n\ndef torow:\n  \"<tr>\",\n  (.[]|tocell),\n  \"</tr>\";\n\ndef totable: \n  \"<table border=1>\",\n  (.[] | torow),\n  \"</table>\";\n\n[[.[]] \n | (map(.date) | unique) as $dates\n | [\"NA\"] + $dates,  # header row\n   (group_by(.uid)\n    | .[]\n    | .[0].uid as $uid\n    | INDEX(.date) as $dict\n    | [$uid, $dict[$dates[]].reg]\n    | map(. // \"-\") ) ]\n| totable\n'"
    ],
    "utterance": "Transpose a dataset so that each row is a user, each column is a date, and cells contain the user's 'reg' and 'ot' values for that date or '-' if absent, output as an HTML table.",
    "expressions": [
      "jq -r '\n\ndef tocell:\n  \"<td>\\(.)</td>\";\n\ndef torow:\n  \"<tr>\",\n  (.[]|tocell),\n  \"</tr>\";\n\ndef totable: \n  \"<table border=1>\",\n  (.[] | torow),\n  \"</table>\";\n\n[[.[]] \n | (map(.date) | unique) as $dates\n | [\"NA\"] + $dates,  # header row\n   (group_by(.uid)\n    | .[]\n    | .[0].uid as $uid\n    | INDEX(.date) as $dict\n    | [$uid, $dict[$dates[]].reg]\n    | map(. // \"-\") ) ]\n| totable\n'"
    ],
    "data": [
      {
        "input": {
          "30814": {
            "uid": "Joe.Jones",
            "date": "2023-05-02",
            "reg": "7.13",
            "ot": "0.00"
          },
          "30870": {
            "uid": "Joe.Jones",
            "date": "2023-05-03",
            "reg": "7.48",
            "ot": "0.00"
          },
          "30906": {
            "uid": "Hank.Joans",
            "date": "2023-05-02",
            "reg": "6.37",
            "ot": "0.00"
          },
          "31079": {
            "uid": "Some.User",
            "date": "2023-05-01",
            "reg": "5.82",
            "ot": "0.00"
          },
          "31125": {
            "uid": "Some.User",
            "date": "2023-05-02",
            "reg": "7.28",
            "ot": "0.00"
          }
        },
        "output": "<table border=1>\n<tr>\n <td> NA</td><td>2023-05-01</td><td>2023-05-02</td><td>2023-05-03</td>\n</tr>\n<tr>\n <td>Joe.Jones</td><td>-</td><td>7.13/0.00</td><td>7.48/0.00</td>\n</tr>\n<tr>\n <td>Hank.Joans</td><td>-</td><td>6.37/0.00</td><td>-</td>\n</tr>\n<tr>\n <td>Some.User</td><td>5.82/0.00</td><td>7.28/0.00</td><td>-</td>\n</tr>\n</table>"
      }
    ],
    "identifier": 76361170
  },
  {
    "context": [
      "From that JSON, I need to get all ipv4 from vm_network[] that have an entry at mac_address[] and I need to print that as \r\n$guest_name, $mac_address, $ipv4",
      "The output i need is:\r\nguest1,00:01:02:03:04:05,192.168.2.23\r\nguest2,10:11:12:13:14:15,172.20.8.34\r\nguest2,30:31:32:33:34:35,172.16.172.34\r\nguest2,30:31:32:33:34:35,172.16.172.30\r\n",
      "Bind values to variables, so you can re-use them later:\r\n```sh\r\n.virtual_machines[] | .guest_name as $g | .mac_address[] as $m\r\n| .vm_network[$m].ipv4[] | [$g, $m, .] | join(\",\")\r\n```",
      "A solution that does not use variables:\r\n\r\n```jq\r\n.virtual_machines\r\n| map(\r\n  { guest_name, mac_address: .mac_address[], ipv4: .vm_network | map_values(.ipv4) }\r\n  | { guest_name, mac_address, ipv4: (.ipv4[.mac_address] // [])[] }\r\n)\r\n| .[]\r\n| join(\",\")\r\n```"
    ],
    "utterance": "For each guest, output the guest_name, each mac_address present, and all associated ipv4 addresses where the mac_address exists in vm_network, as comma-separated values.",
    "expressions": [
      ".virtual_machines[] | .guest_name as $g | .mac_address[] as $m | .vm_network[$m].ipv4[] | [$g, $m, .] | join(\",\")",
      ".virtual_machines | map({ guest_name, mac_address: .mac_address[], ipv4: .vm_network | map_values(.ipv4) } | { guest_name, mac_address, ipv4: (.ipv4[.mac_address] // [])[] }) | .[] | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "virtual_machines": [
            {
              "guest_name": "guest1",
              "mac_address": [
                "00:01:02:03:04:05"
              ],
              "vm_network": {
                "00:01:02:03:04:05": {
                  "ipv4": [
                    "192.168.2.23"
                  ],
                  "ipv6": [
                    "fe80::896:2e12:c059:4237"
                  ]
                },
                "c2:e3:7c:ac:60:c5": {
                  "ipv4": [
                    "10.42.0.0"
                  ],
                  "ipv6": []
                },
                "5a:00:fb:5e:3d:65": {
                  "ipv4": [
                    "10.42.0.1"
                  ],
                  "ipv6": []
                }
              }
            },
            {
              "guest_name": "guest2",
              "ip_address": "172.20.8.34",
              "mac_address": [
                "10:11:12:13:14:15",
                "30:31:32:33:34:35"
              ],
              "vm_network": {
                "10:11:12:13:14:15": {
                  "ipv4": [
                    "172.20.8.34"
                  ],
                  "ipv6": []
                },
                "30:31:32:33:34:35": {
                  "ipv4": [
                    "172.16.172.34",
                    "172.16.172.30"
                  ],
                  "ipv6": [
                    "fe80::ad7f:c2:f621:e718"
                  ]
                }
              }
            }
          ]
        },
        "output": [
          "guest1,00:01:02:03:04:05,192.168.2.23",
          "guest2,10:11:12:13:14:15,172.20.8.34",
          "guest2,30:31:32:33:34:35,172.16.172.34",
          "guest2,30:31:32:33:34:35,172.16.172.30"
        ]
      }
    ],
    "identifier": 76367028
  },
  {
    "context": [
      "I want to combine below mentioned 2 jq commands to work together in a single jq command.",
      "Command 1:\njq -r '.objects[] | \"\\(.name),\\(.uid),\\(.type),\\(.\\\"ipv4-address\\\"),\\(.\\\"nat-settings\\\".\\\"ipv4-address\\\"),\\(.\\\"nat-settings\\\".\\\"ipv6-address\\\"),\\(.\\\"nat-settings\\\".\\\"install-on\\\"),\\(.\\\"nat-settings\\\".method)\"'",
      "Command 2:\njq -r '.objects[].groups[].name'",
      "I'm able to get output of commands when executed separately but I'm not getting any output after combining both.",
      "Expected Output:\nBL_2.2.2.2,11c758bf-15d7-47ba-af1a-200ffa171587,host,2.2.2.2,66.66.66.66,,All,hide,network11111,workrrorxzdg",
      "With all fields (from OP):\n.objects[] | \"\\(.name),\\(.uid),\\(.type),\\(.\\\"ipv4-address\\\"),\\(.\\\"nat-settings\\\".\\\"ipv4-address\\\"),\\(.\\\"nat-settings\\\".\\\"ipv6-address\\\"),\\(.\\\"nat-settings\\\".\\\"install-on\\\"),\\(.\\\"nat-settings\\\".method),\\(.groups[].name)\"",
      "OP's comment, output as a single line:\nUse join() in the string literal:\n.objects[] | \"\\(.name),\\(.uid),\\(.type),\\(.\\\"ipv4-address\\\"),\\(.\\\"nat-settings\\\".\\\"ipv4-address\\\"),\\(.\\\"nat-settings\\\".\\\"ipv6-address\\\"),\\(.\\\"nat-settings\\\".\\\"install-on\\\"),\\(.\\\"nat-settings\\\".method),\\([ .groups[].name ] | join(\",\"))\"",
      "The edited output is even simpler: Just iterate over the array:\n.objects[] | [ .name, .uid, .type,\n  .\"ipv4-address\", .\"nat-settings\".\"ipv4-address\", .\"nat-settings\".\"ipv6-address\",\n  .\"nat-settings\".\"install-on\", .\"nat-settings\".method, .groups[].name\n] | join(\",\")  # or @csv",
      "BL_2.2.2.2,11c758bf-15d7-47ba-af1a-200ffa171587,host,2.2.2.2,66.66.66.66,,All,hide,network11111,workrrorxzdg"
    ],
    "utterance": "Extract name, uid, type, ipv4-address, nat-settings fields (ipv4-address, ipv6-address, install-on, method), and all group names for each object, outputting them as a single comma-separated line with all group names appended.",
    "expressions": [
      ".objects[] | [ .name, .uid, .type, .\"ipv4-address\", .\"nat-settings\".\"ipv4-address\", .\"nat-settings\".\"ipv6-address\", .\"nat-settings\".\"install-on\", .\"nat-settings\".method ] + ( [ .groups[].name ] ) | join(\",\")",
      ".objects[] | [ .name, .uid, .type, .\"ipv4-address\", .\"nat-settings\".\"ipv4-address\", .\"nat-settings\".\"ipv6-address\", .\"nat-settings\".\"install-on\", .\"nat-settings\".method, (.groups[].name) ] | join(\",\")",
      ".objects[] | [ .name, .uid, .type, .\"ipv4-address\", .\"nat-settings\".\"ipv4-address\", .\"nat-settings\".\"ipv6-address\", .\"nat-settings\".\"install-on\", .\"nat-settings\".method, ([.groups[].name] | join(\",\")) ] | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "from": 1,
          "to": 1,
          "total": 1,
          "objects": [
            {
              "uid": "11c758bf-15d7-47ba-af1a-200ffa171587",
              "name": "BL_2.2.2.2",
              "type": "host",
              "domain": {
                "uid": "41e821a0-3720-11e3-aa6e-0800200c9fde",
                "name": "SMC User",
                "domain-type": "domain"
              },
              "ipv4-address": "2.2.2.2",
              "interfaces": [],
              "nat-settings": {
                "auto-rule": true,
                "ipv4-address": "66.66.66.66",
                "ipv6-address": "",
                "hide-behind": "ip-address",
                "install-on": "All",
                "method": "hide"
              },
              "groups": [
                {
                  "uid": "eebedbc9-ef19-4c68-91d2-cd6ea3fec11d",
                  "name": "network11111",
                  "type": "group",
                  "domain": {
                    "uid": "41e821a0-3720-11e3-aa6e-0800200c9fde",
                    "name": "SMC User",
                    "domain-type": "domain"
                  },
                  "members": [
                    "11c758bf-15d7-47ba-af1a-200ffa171587"
                  ],
                  "groups": [],
                  "comments": "",
                  "color": "black",
                  "icon": "General/group",
                  "tags": [],
                  "meta-info": {
                    "lock": "unlocked",
                    "validation-state": "ok",
                    "last-modify-time": {
                      "posix": 1683719146105,
                      "iso-8601": "2023-05-10T17:15+0530"
                    },
                    "last-modifier": "admin",
                    "creation-time": {
                      "posix": 1683719146105,
                      "iso-8601": "2023-05-10T17:15+0530"
                    },
                    "creator": "admin"
                  },
                  "read-only": false,
                  "available-actions": {
                    "edit": "true",
                    "delete": "true",
                    "clone": "true"
                  }
                },
                {
                  "uid": "f04b042d-0a37-4a10-b470-08ca0e18a129",
                  "name": "workrrorxzdg",
                  "type": "group",
                  "domain": {
                    "uid": "41e821a0-3720-11e3-aa6e-0800200c9fde",
                    "name": "SMC User",
                    "domain-type": "domain"
                  },
                  "members": [
                    "11c758bf-15d7-47ba-af1a-200ffa171587"
                  ],
                  "groups": [],
                  "comments": "",
                  "color": "black",
                  "icon": "General/group",
                  "tags": [],
                  "meta-info": {
                    "lock": "unlocked",
                    "validation-state": "ok",
                    "last-modify-time": {
                      "posix": 1683719351164,
                      "iso-8601": "2023-05-10T17:19+0530"
                    },
                    "last-modifier": "admin",
                    "creation-time": {
                      "posix": 1683719351164,
                      "iso-8601": "2023-05-10T17:19+0530"
                    },
                    "creator": "admin"
                  },
                  "read-only": false,
                  "available-actions": {
                    "edit": "true",
                    "delete": "true",
                    "clone": "true"
                  }
                }
              ],
              "comments": "",
              "color": "black",
              "icon": "Objects/host",
              "tags": [],
              "meta-info": {
                "lock": "unlocked",
                "validation-state": "ok",
                "last-modify-time": {
                  "posix": 1683514434876,
                  "iso-8601": "2023-05-08T08:23+0530"
                },
                "last-modifier": "admin",
                "creation-time": {
                  "posix": 1683514434876,
                  "iso-8601": "2023-05-08T08:23+0530"
                },
                "creator": "admin"
              },
              "read-only": false,
              "available-actions": {
                "edit": "true",
                "delete": "true",
                "clone": "true"
              }
            }
          ]
        },
        "output": "BL_2.2.2.2,11c758bf-15d7-47ba-af1a-200ffa171587,host,2.2.2.2,66.66.66.66,,All,hide,network11111,workrrorxzdg"
      }
    ],
    "identifier": 76218573
  },
  {
    "context": [
      "I need to convert the output to json format, splitting by leading spaces and assigning the value present on the first row of each group to the \"Key\" field, then there may be subfields for example under the \"Metadata\" value:",
      "With jq, you can read in raw text using the `-R` flag, and iterate through the lines using `reduce`. Start out with an empty array `[]`, then, based on the indentation, add a new item, append to the `last` one, or append to `last` one's `.Metadata` field. Checking the indentation and parsing the line's content is done using regular expressions with `match` and `capture`, respectively:",
      "jq -Rn '\n  reduce (inputs | {\n    ind: match(\"^\\\\s*\").length,\n    cap: capture(\"\\\\s*(?<key>.*):(\\\\s+(?<value>.*))?$\")\n  }) as {$ind, $cap} ([];\n    if $ind == 0 then . + [$cap | {key}]\n    elif $ind == 4 then last += ([$cap | select(.key == \"Metadata\").value = {}] | from_entries)\n    elif $ind == 8 then last.Metadata += ([$cap] | from_entries)\n    else . end\n  )\n'"
    ],
    "utterance": "Convert indented object metadata text into an array of objects, assigning each object's bucket path to the Key field and nesting subfields like meta-1 and meta-2 under the Metadata key.",
    "expressions": [
      "jq -Rn '\n  reduce (inputs | {\n    ind: match(\"^\\\\s*\").length,\n    cap: capture(\"\\\\s*(?<key>.*):(\\\\s+(?<value>.*))?$\")\n  }) as {$ind, $cap} ([];\n    if $ind == 0 then . + [$cap | {key}]\n    elif $ind == 4 then last += ([$cap | select(.key == \"Metadata\").value = {}] | from_entries)\n    elif $ind == 8 then last.Metadata += ([$cap] | from_entries)\n    else . end\n  )\n'"
    ],
    "data": [
      {
        "input": "gs://bucket-test/4e123978-8eed-43ae-f521-8fba54c704ea.zip:\n    Creation time:          Wed, 21 Dec 2022 10:39:27 GMT\n    Update time:            Wed, 21 Dec 2022 10:39:27 GMT\n    Storage class:          STANDARD\n    Content-Length:         0\n    Content-Type:           application/zip\n    Hash (crc32c):          AAAAAA==\n    Hash (md5):             1B2M2Y8AsgTpgAmY7PhCfg==\n    ETag:                   CM30q9XCivwCEAE=\n    Generation:             1671619167320653\n    Metageneration:         1\ngs://bucket-test/GKiSQMZ5rAqrSWwur/uploads/GENERAL/SNrQD97nzQN9eDLeA/AAZYefiL5CT8pxe4L:\n    Creation time:          Mon, 10 Apr 2023 19:09:41 GMT\n    Update time:            Mon, 10 Apr 2023 19:09:41 GMT\n    Storage class:          STANDARD\n    Content-Disposition:    inline; filename=James_INGREDIENTS_A3.pdf\n    Content-Length:         4381797\n    Content-Type:           application/pdf\n    Hash (crc32c):          GOzitA==\n    Hash (md5):             eUSLC/z70gjDB2WQKIPOuQ==\n    ETag:                   CLGPvu+BoP4CEAE=\n    Generation:             1681153781106609\n    Metageneration:         1\ngs://bucket-test/prova.pdf:\n    Creation time:          Mon, 08 May 2023 15:37:26 GMT\n    Update time:            Mon, 08 May 2023 15:40:12 GMT\n    Storage class:          STANDARD\n    Content-Disposition:    inline; filename=James_KEY_VISUAL_A3.pdf\n    Content-Language:       ace\n    Content-Length:         15407\n    Content-Type:           application/pdf\n    Metadata:               \n        meta-1:             prova 1\n        meta-2:             prova 2\n    Hash (crc32c):          ZIrHPA==\n    Hash (md5):             oZbD+S8y35spkNozW3hUDA==\n    ETag:                   CNDj09OG5v4CEAM=\n    Generation:             1683560246604240\n    Metageneration:         3\n",
        "output": [
          {
            "key": "gs://bucket-test/4e123978-8eed-43ae-f521-8fba54c704ea.zip",
            "Creation time": "Wed, 21 Dec 2022 10:39:27 GMT",
            "Update time": "Wed, 21 Dec 2022 10:39:27 GMT",
            "Storage class": "STANDARD",
            "Content-Length": "0",
            "Content-Type": "application/zip",
            "Hash (crc32c)": "AAAAAA==",
            "Hash (md5)": "1B2M2Y8AsgTpgAmY7PhCfg==",
            "ETag": "CM30q9XCivwCEAE=",
            "Generation": "1671619167320653",
            "Metageneration": "1"
          },
          {
            "key": "gs://bucket-test/GKiSQMZ5rAqrSWwur/uploads/GENERAL/SNrQD97nzQN9eDLeA/AAZYefiL5CT8pxe4L",
            "Creation time": "Mon, 10 Apr 2023 19:09:41 GMT",
            "Update time": "Mon, 10 Apr 2023 19:09:41 GMT",
            "Storage class": "STANDARD",
            "Content-Disposition": "inline; filename=James_INGREDIENTS_A3.pdf",
            "Content-Length": "4381797",
            "Content-Type": "application/pdf",
            "Hash (crc32c)": "GOzitA==",
            "Hash (md5)": "eUSLC/z70gjDB2WQKIPOuQ==",
            "ETag": "CLGPvu+BoP4CEAE=",
            "Generation": "1681153781106609",
            "Metageneration": "1"
          },
          {
            "key": "gs://bucket-test/prova.pdf",
            "Creation time": "Mon, 08 May 2023 15:37:26 GMT",
            "Update time": "Mon, 08 May 2023 15:40:12 GMT",
            "Storage class": "STANDARD",
            "Content-Disposition": "inline; filename=James_KEY_VISUAL_A3.pdf",
            "Content-Language": "ace",
            "Content-Length": "15407",
            "Content-Type": "application/pdf",
            "Metadata": {
              "meta-1": "prova 1",
              "meta-2": "prova 2"
            },
            "Hash (crc32c)": "ZIrHPA==",
            "Hash (md5)": "oZbD+S8y35spkNozW3hUDA==",
            "ETag": "CNDj09OG5v4CEAM=",
            "Generation": "1683560246604240",
            "Metageneration": "3"
          }
        ]
      }
    ],
    "identifier": 76209557
  },
  {
    "identifier": 76406175
  },
  {
    "context": [
      "but I would like to use jq to parse the json and output from one compiled c file. how do i do this without doing: ``` ./mycurl | jq ```",
      "here is how you could pass the data to `jq`:\n\n```\n#define _POSIX_C_SOURCE 2\n#include <curl/curl.h>\n#include <stdio.h>\n#include <sys/wait.h>\n#include <unistd.h>\n\nint main(void) {\n\tFILE *f = popen(\"jq .userId\", \"w\");\n\tif(!f) {\n\t\tprintf(\"jq failed\\n\");\n\t\treturn 1;\n\t}\n\tdup2(fileno(f), STDOUT_FILENO);\n\tCURL *ch = curl_easy_init();\n\tcurl_easy_setopt(ch, CURLOPT_URL, \"https://jsonplaceholder.typicode.com/todos/2\");\n\tCURLcode res = curl_easy_perform(ch);\n\tcurl_easy_cleanup(ch);\n\tfclose(stdout);\n\treturn pclose(f);\n}\n```",
      "and output:\n\n```\n1\n```"
    ],
    "utterance": "Extract the value of the userId property from the response to https://jsonplaceholder.typicode.com/todos/2",
    "expressions": [
      ".userId"
    ],
    "data": [
      {
        "input": {
          "userId": 1,
          "id": 2,
          "title": "quis ut nam facilis et officia qui",
          "completed": false
        },
        "output": 1
      }
    ],
    "identifier": 76402614
  },
  {
    "context": [
      "I have two simple JSON objects, I'm trying to add a single object from a Bash variable `newValArr` in order of the corresponding objects to the `masterfile.json`.",
      "I\u2019ve created the following in Bash that adds the `firstValue` and `secondValue` object in the intended spot in the `value` array of objects, here is the script:\n\n```\njq --argjson newvalues \"${newValArr}\" '.value[].properties.newObject += $newvalues[0]' masterfile.json > newoutput.json\n```",
      "The problem obviously is that the same `newValArr` object is being placed into every single `newObject` as we're continually referencing the same index.",
      "The two JSON's will always have the same number of objects, in the same order, no need to worry about that.",
      "One way to do it is create a range of all the indexes of the arrays and build a new object by combining the corresponding elements:",
      "jq -n --argjson newval \"$newValArr\" --argfile master masterfile.json '\n   { value: [ range($master.value | length)\n              | . as $n\n              | $master.value[$n] * { properties: { newObject: $newval[$n] } }\n            ]\n   }'",
      "Or another approach that uses `transpose` to [zip the two arrays][1] together and then merges them:",
      "jq --argjson newval \"$newValArr\" '\n   .value |= [ [ ., $newval ] | transpose[] | .[0] * { properties: { newObject: .[1] }} ]\n' masterfile.json",
      "You could use `to_entries` which, when applied to an array, generates indices in the `.key` field, which then can be used to index into the imported variable.",
      "jq --argjson vals \"$newValArr\" '.value |= (to_entries | map(\n  $vals[.key] as $newObject | .value | .properties += {$newObject}\n))' masterfile.json"
    ],
    "utterance": "For each object in the value array, insert the corresponding object from newValArr as properties.newObject, preserving the order.",
    "expressions": [
      ".value |= [ [ ., $newval ] | transpose[] | .[0] * { properties: { newObject: .[1] }} ]",
      ".value |= (to_entries | map($vals[.key] as $newObject | .value | .properties += {newObject: $newObject}))"
    ],
    "data": [
      {
        "input": {
          "value": [
            {
              "id": "abc",
              "properties": {
                "blah": "stuff"
              }
            },
            {
              "id": "def",
              "properties": {
                "blah": "morestuff"
              }
            }
          ]
        },
        "output": {
          "value": [
            {
              "id": "abc",
              "properties": {
                "blah": "stuff",
                "newObject": {
                  "firstValue": "foo",
                  "secondValue": "bar"
                }
              }
            },
            {
              "id": "def",
              "properties": {
                "blah": "morestuff",
                "newObject": {
                  "firstValue": "baz",
                  "secondValue": "qux"
                }
              }
            }
          ]
        }
      },
      {
        "input": [
          {
            "firstValue": "foo",
            "secondValue": "bar"
          },
          {
            "firstValue": "baz",
            "secondValue": "qux"
          }
        ]
      }
    ],
    "identifier": 76319135
  },
  {
    "context": [
      "I have this input:\r\n\r\n    { \"k1\": \"v1\", \"k2\": \"v2\" }\r\n\r\nI want to get this:\r\n\r\n    { \"v1\": \"v2\" }\r\n",
      "Here is a way:\r\n```\r\n{(.k1): .k2}\r\n```"
    ],
    "utterance": "Transform an object with keys k1 and k2 so that the value of k1 becomes the key and the value of k2 becomes the value of a new object.",
    "expressions": [
      "{(.k1): .k2}"
    ],
    "data": [
      {
        "input": {
          "k1": "v1",
          "k2": "v2"
        },
        "output": {
          "v1": "v2"
        }
      }
    ],
    "identifier": 76409375
  },
  {
    "context": [
      "My goal is to select only the variable names containing the `description` field.",
      "So the desired output is (don\u2019t care about the order):\n\n```json\nAWS_REGION\nENVIRONMENT\n```",
      "But I\u2019m stuck removing the ones without `description`.",
      "Use `to_entries` to get simultaneous access to both the `.key` and the `.value`, test the existence of a (sub-)key using `has`, and use `?` to suppress errors if it is not an object (thus has no key, and would error out).",
      "jq -r '.variables | to_entries[] | select(.value | has(\"description\" )?).key'",
      "jq -r '.variables | keys[] as $k | .[$k] | select(has(\"description\")?) | $k'"
    ],
    "utterance": "Output the variable names whose value contains a 'description' field.",
    "expressions": [
      ".variables | to_entries[] | select(.value | has(\"description\")?).key",
      ".variables | keys[] as $k | .[$k] | select(has(\"description\")?) | $k"
    ],
    "data": [
      {
        "input": {
          "variables": {
            "AWS_ROLE": "DevOpsAccessRole",
            "AWS_REGION": {
              "description": "AWS region",
              "value": "us-west-2",
              "options": [
                "us-west-2",
                "us-east-1"
              ]
            },
            "ENVIRONMENT": {
              "description": "Environment to deploy to",
              "value": "dev",
              "options": [
                "dev",
                "qa",
                "prod"
              ]
            }
          }
        },
        "output": [
          "AWS_REGION",
          "ENVIRONMENT"
        ]
      }
    ],
    "identifier": 76423585
  },
  {
    "context": [
      "I need to transform `data` into another format and output must be:\r\n\r\n```\r\n{\r\n  \"name\": \"Ted Mosby\",\r\n  \"addresses\": {\r\n      \"data\": [{\r\n        \"value\": \"any xpto\",\r\n        \"remoteRef\": {\r\n            \"key\": \"address key\",\r\n            \"courrierStrategy\": \"Auto\"\r\n        }\r\n      }]\r\n  }\r\n}\r\n```",
      "You could update `|=` the `.data` array by applying a transformation to each of its elements, using the `.key` and `.value` from the original item:\r\n```\r\n.addresses.data |= map({value, remoteRef: {key, courrierStrategy: \"Auto\"}})\r\n```"
    ],
    "utterance": "Restructure each item in addresses.data to contain value at the top level and embed key along with a fixed courrierStrategy: \"Auto\" inside a nested remoteRef object.",
    "expressions": [
      ".addresses.data |= map({value, remoteRef: {key, courrierStrategy: \"Auto\"}})"
    ],
    "data": [
      {
        "input": {
          "name": "Ted Mosby",
          "addresses": {
            "data": [
              {
                "key": "address key",
                "value": "any xpto"
              }
            ]
          }
        },
        "output": {
          "name": "Ted Mosby",
          "addresses": {
            "data": [
              {
                "value": "any xpto",
                "remoteRef": {
                  "key": "address key",
                  "courrierStrategy": "Auto"
                }
              }
            ]
          }
        }
      }
    ],
    "identifier": 76426251
  },
  {
    "context": [
      "I have the following input file\n```\n[\"alice\", [\"foo\", \"bar\", \"baz\"]]\n[\"bob\", [\"qux\", \"quux\"]]\n\u22ee\n```",
      "I want to convert it to a tab separated file that looks like the following (note the lack of quotes)\n```\nalice   foo\nalice   bar\nalice   baz\nbob     qux\nbob     quux\n\u22ee\n```",
      "Replace the `last` item (or equally the `.[1]` item) with each of its own items (`.[]`), then turn all of it into tab-separated values using `@tsv`:",
      "jq -r 'last = last[] | @tsv' input.json",
      "Here's another way to do it by placing the first element in an array and then using the built-in [`combinations`](https://jqlang.github.io/jq/manual/v1.6/#combinations,combinations(n)).",
      "jq --raw-output '.[0]=[.[0]] | combinations | @tsv' input.json"
    ],
    "utterance": "Produce a tab-separated output with each line containing the first element paired with each item from the second array for every input line.",
    "expressions": [
      "last = last[] | @tsv",
      ".[0]=[.[0]] | combinations | @tsv"
    ],
    "data": [
      {
        "input": [
          [
            "alice",
            [
              "foo",
              "bar",
              "baz"
            ]
          ],
          [
            "bob",
            [
              "qux",
              "quux"
            ]
          ]
        ],
        "output": [
          "alice\tfoo",
          "alice\tbar",
          "alice\tbaz",
          "bob\tqux",
          "bob\tquux"
        ]
      }
    ],
    "identifier": 76430218
  },
  {
    "context": [
      "I would like to extract the two json objects `details` and `properties` and and insert into `item`, replacing all other properties.",
      "Edit: With the updated input files, just add `{properties}` as is (replacing `.properties`):",
      "jq '.items[] |= .details + {properties}'",
      "jq '.items[] |= .details + {\"properties\": .properties}'",
      "There are many possible solutions as evidenced by the existing great answers. One solution takes the constructive, albeit slightly repetetive, approach:",
      "{ items: .items | map({ name: .details.name, description: .details.description, properties }) }"
    ],
    "utterance": "Replace each element of the items array with an object containing the merged fields from details and properties, discarding all other keys.",
    "expressions": [
      ".items[] |= .details + {properties}",
      ".items[] |= .details + {\"properties\": .properties}",
      "{items: .items | map({name: .details.name, description: .details.description, properties})}",
      ".items[] |= {name: .details.name, description: .details.description, properties}"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "details": {
                "name": "test",
                "description": "description"
              },
              "properties": [
                {
                  "property1": "someValue",
                  "property2": "someOtherValue"
                }
              ],
              "additionalProperties": {
                "other": "stuff"
              }
            },
            {
              "details": {
                "name": "test2",
                "description": "description2"
              },
              "properties": [
                {
                  "property1": "someValue2",
                  "property2": "someOtherValue2"
                }
              ],
              "additionalProperties": {
                "other": "stuff"
              }
            }
          ]
        },
        "output": {
          "items": [
            {
              "name": "test",
              "description": "description",
              "properties": [
                {
                  "property1": "someValue",
                  "property2": "someOtherValue"
                }
              ]
            },
            {
              "name": "test2",
              "description": "description2",
              "properties": [
                {
                  "property1": "someValue2",
                  "property2": "someOtherValue2"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 76407533
  },
  {
    "context": [
      "I want to get the value of the `PublicIpAddress`",
      "So far i've tried `aws ec2 describe-instances | jq '.[] | {publicIP : .Reservations.Instances[].PublicIpAddress}'` as well as `aws ec2 describe-instances | jq '.[] | {publicIP : .Reservations.Instances.PublicIpAddress}'` but i keep running into `jq: error (at <stdin>:151): Cannot index array with string \"Reservations\"`",
      "I *think* you want the following:\n\n```\n.Reservations[].Instances[] | { publicIp: .PublicIpAddress }\n```",
      "Output:\n\n```\n{\n  \"publicIp\": \"54.11.101.63\"\n}\n```",
      "Alternative spellings of the same program:\n\n```\n.Reservations[].Instances[].PublicIpAddress | { publicIp: . }\n.Reservations[] | { publicIp: .Instances[].PublicIpAddress }\n{ publicIp: .Reservations[].Instances[].PublicIpAddress }\n```",
      "But maybe you are really looking for this?\n\n```\njq -r '.Reservations[].Instances[].PublicIpAddress'\n```\n\nWhich will simply output `54.11.101.63` (one IP address per line, if there are multiple in your input document)."
    ],
    "utterance": "Extract the PublicIpAddress from all Instances within all Reservations.",
    "expressions": [
      ".Reservations[].Instances[] | { publicIp: .PublicIpAddress }",
      ".Reservations[].Instances[].PublicIpAddress | { publicIp: . }",
      ".Reservations[] | { publicIp: .Instances[].PublicIpAddress }",
      "{ publicIp: .Reservations[].Instances[].PublicIpAddress }",
      ".Reservations[].Instances[].PublicIpAddress"
    ],
    "data": [
      {
        "input": {
          "Reservations": [
            {
              "Groups": [],
              "Instances": [
                {
                  "AmiLaunchIndex": 0,
                  "ImageId": "ami-XXX",
                  "InstanceId": "i-XXX",
                  "InstanceType": "t2.micro",
                  "KeyName": "dev",
                  "LaunchTime": "2022-06-04T22:30:04+00:00",
                  "Monitoring": {
                    "State": "disabled"
                  },
                  "Placement": {
                    "AvailabilityZone": "us-east-1d",
                    "GroupName": "",
                    "Tenancy": "default"
                  },
                  "PrivateDnsName": "ip-172-28-99-112.ec2.internal",
                  "PrivateIpAddress": "172.28.99.112",
                  "ProductCodes": [],
                  "PublicDnsName": "ec2-54-11-101-63.compute-1.amazonaws.com",
                  "PublicIpAddress": "54.11.101.63",
                  "State": {
                    "Code": 16,
                    "Name": "running"
                  }
                }
              ]
            }
          ]
        },
        "output": [
          {
            "publicIp": "54.11.101.63"
          }
        ]
      }
    ],
    "identifier": 76402740
  },
  {
    "context": [
      "I want to find the build number of the last branch that was built.",
      "The logic to do so is to find the name of the branch `.lastBuiltRevision.branch[0].name` = `origin/master`. Then use the branch name to find the build number `.buildsByBranchName | to_entries[] | select(.\"key\" == \"origin/master\") .value.buildNumber` = `28694`. But I don't know how to combine them.",
      "After `.buildsByBranchName` I have no access to `lastBuiltRevision` in my select. Or is there any way?",
      "There's no need for `select()`, you can use the branch as the desired key in `buildByBranchName`:",
      ".buildsByBranchName[.lastBuiltRevision.branch[0].name].buildNumber",
      "Should you need to use the `.lastBuiltRevision.branch[0].name` on more places, consider setting a variable:",
      ".lastBuiltRevision.branch[0].name as $branch | .buildsByBranchName[$branch].buildNumber"
    ],
    "utterance": "Retrieve the build number corresponding to the branch name specified in the first element of lastBuiltRevision.branch.",
    "expressions": [
      ".buildsByBranchName[.lastBuiltRevision.branch[0].name].buildNumber",
      ".lastBuiltRevision.branch[0].name as $branch | .buildsByBranchName[$branch].buildNumber"
    ],
    "data": [
      {
        "input": {
          "buildsByBranchName": {
            "origin/master": {
              "buildNumber": 28694
            },
            "master": {
              "buildNumber": 28563
            },
            "refs/remotes/origin/master": {
              "buildNumber": 4094
            }
          },
          "lastBuiltRevision": {
            "branch": [
              {
                "name": "origin/master"
              }
            ]
          }
        },
        "output": 28694
      }
    ],
    "identifier": 76432932
  },
  {
    "context": [
      "I want to filter a subset of this, modify it and append it to a file (sub_meta.json).",
      "sub_meta:json would contain an empty array to start with. I need to keep appending such values to fill it up",
      "Supposing you only want the modified item to be added to the array in `sub_meta.json`: You can load `full_meta.json` as a variable, modify it as you see fit, read `sub_meta.json` as input, append the modification to it, write the result into a temporary file, and if all was successful, replace the old `sub_meta.json` file with the new (temporary) output file.",
      "jq --argfile f full_meta.json \\\n  '. + [$f[] | select(.product_id == \"881\") | .product_id = \"881-new\"]' \\\n  sub_meta.json > sub_meta.tmp && mv sub_meta.tmp sub_meta.json"
    ],
    "utterance": "Append all objects from full_meta.json with product_id equal to \"881\", after changing their product_id to \"881-new\", to the array in sub_meta.json.",
    "expressions": [
      ". + [$f[] | select(.product_id == \"881\") | .product_id = \"881-new\"]"
    ],
    "data": [
      {
        "input": [
          {
            "product_id": "xxx",
            "name": "yyy",
            "qty": 111
          },
          {
            "product_id": "881",
            "name": "aaa",
            "qty": 200
          }
        ],
        "output": [
          {
            "product_id": "881-new",
            "name": "aaa",
            "qty": 200
          }
        ]
      }
    ],
    "identifier": 76445806
  },
  {
    "context": [
      "I would like to use `jq` to process all these files and produce an output:",
      "/path/to/dir1/f1.json,0.76",
      "/path/to/dir2/f1.json,0.89",
      "/path/to/dir1/f12.json,0.98",
      "Use `input_filename` to get the file names, string interpolation `\"\\(...)\"` to compose and the `-r` flag to output text:",
      "jq -r '\"\\(input_filename),\\(.score)\"' /path/to/*/*.json",
      "/path/to/dir1/f12.json,0.98",
      "/path/to/dir1/f1.json,0.76",
      "/path/to/dir2/f1.json,0.89"
    ],
    "utterance": "For each file in a list, output the file path and its score value separated by a comma.",
    "expressions": [
      "jq -r '\"\\(input_filename),\\(.score)\"' /path/to/*/*.json"
    ],
    "data": [
      {
        "input": [
          {
            "file": "/path/to/dir1/f1.json",
            "content": {
              "score": 0.76
            }
          },
          {
            "file": "/path/to/dir2/f1.json",
            "content": {
              "score": 0.89
            }
          },
          {
            "file": "/path/to/dir1/f12.json",
            "content": {
              "score": 0.98
            }
          }
        ],
        "output": [
          "/path/to/dir1/f1.json,0.76",
          "/path/to/dir2/f1.json,0.89",
          "/path/to/dir1/f12.json,0.98"
        ]
      }
    ],
    "identifier": 76458159
  },
  {
    "context": [
      "But I do not need double quotes and second field should be 0.18 instead of 0.1833",
      "jq -r '.Datapoints\n| sort_by(.Timestamp)[]\n| [.Timestamp, (.Average*100|round/100)]\n| @csv' output.txt"
    ],
    "utterance": "Output each Datapoint's Timestamp and its Average rounded to two decimal places, sorted by Timestamp, as a CSV line without enclosing double quotes around numbers.",
    "expressions": [
      ".Datapoints | sort_by(.Timestamp)[] | [.Timestamp, (.Average*100|round/100)] | @csv"
    ],
    "data": [
      {
        "input": {
          "Label": "DBLoad",
          "Datapoints": [
            {
              "Timestamp": "2023-06-12T08:19:00+00:00",
              "Average": 0.18333333333333332,
              "Unit": "None"
            },
            {
              "Timestamp": "2023-06-12T04:10:00+00:00",
              "Average": 0.03333333333333333,
              "Unit": "None"
            },
            {
              "Timestamp": "2023-06-12T07:42:00+00:00",
              "Average": 0.03333333333333333,
              "Unit": "None"
            },
            {
              "Timestamp": "2023-06-12T03:33:00+00:00",
              "Average": 0,
              "Unit": "None"
            }
          ]
        },
        "output": [
          "\"2023-06-12T03:33:00+00:00\",0",
          "\"2023-06-12T04:10:00+00:00\",0.03",
          "\"2023-06-12T07:42:00+00:00\",0.03",
          "\"2023-06-12T08:19:00+00:00\",0.18"
        ]
      }
    ],
    "identifier": 76455811
  },
  {
    "context": [
      "How do I convert it to the following structure:\r\n\r\n{\r\n  \"value11\": \"value12\",\r\n  \"value21\": \"value22\", \r\n  \"value31\": \"value32\"\r\n}",
      "So, assuming your input with all objects having the same keys looks like\r\n[\r\n  {\r\n    \"key1\": \"value11\",\r\n    \"key2\": \"value12\",\r\n    \"key3\": \"value13\",\r\n    \"key4\": \"value14\"\r\n  },\r\n  {\r\n    \"key1\": \"value21\",\r\n    \"key2\": \"value22\",\r\n    \"key3\": \"value23\",\r\n    \"key4\": \"value24\"\r\n  },\r\n  {\r\n    \"key1\": \"value31\",\r\n    \"key2\": \"value32\",\r\n    \"key3\": \"value33\",\r\n    \"key4\": \"value34\"\r\n  }\r\n]",
      "Then, you could either use map to turn each array item to a single-field object, and then add to combine these objects into one ([Demo](https://jqplay.org/s/J-BW2nCRLon)):\r\njq 'map({(.key1): .key2}) | add' input.json",
      "Or you could reduce the array's items into an initially empty output object {} by iteratively setting another of its keys ([Demo](https://jqplay.org/s/eqhRNYclfP8)):\r\njq 'reduce .[] as $i ({}; .[$i.key1] = $i.key2)' input.json",
      "Both approaches return:\r\n{\r\n  \"value11\": \"value12\",\r\n  \"value21\": \"value22\",\r\n  \"value31\": \"value32\"\r\n}"
    ],
    "utterance": "Convert an array of objects with identical keys to a single object where each key is the 'key1' value and each value is the corresponding 'key2' value from each object.",
    "expressions": [
      "map({(.key1): .key2}) | add",
      "reduce .[] as $i ({}; .[$i.key1] = $i.key2)"
    ],
    "data": [
      {
        "input": [
          {
            "key1": "value11",
            "key2": "value12",
            "key3": "value13",
            "key4": "value14"
          },
          {
            "key1": "value21",
            "key2": "value22",
            "key3": "value23",
            "key4": "value24"
          },
          {
            "key1": "value31",
            "key2": "value32",
            "key3": "value33",
            "key4": "value34"
          }
        ],
        "output": {
          "value11": "value12",
          "value21": "value22",
          "value31": "value32"
        }
      }
    ],
    "identifier": 76443318
  },
  {
    "context": [
      "I have the following JSON object:\n\n{\n...,\n\"projects\": [\n    \"abc\",\n    \"xyz\"\n  ],\n...\n}\n\nAnd I want it transformed to:\n{\n  \"abc\": {\n    \"name\": \"abc\"\n  },\n  \"xyz\": {\n    \"name\": \"xyz\"\n  },\n}",
      "I've tried using `map` as `.projects | map({(.): { \"name\": (.) }} )` but it's not in the format I want and ends up in an array.",
      "You're looking for something like this:\n\n.projects | map({(.): {name: .}}) | add",
      "reduce .projects[] as $name ({}; . + {($name): {name: $name}})"
    ],
    "utterance": "Transform an object with a 'projects' array of strings into an object whose keys are the array values and whose values are objects with a 'name' property set to each string.",
    "expressions": [
      ".projects | map({(.): {name: .}}) | add",
      "reduce .projects[] as $name ({}; . + {($name): {name: $name}})"
    ],
    "data": [
      {
        "input": {
          "projects": [
            "abc",
            "xyz"
          ]
        },
        "output": {
          "abc": {
            "name": "abc"
          },
          "xyz": {
            "name": "xyz"
          }
        }
      }
    ],
    "identifier": 76475789
  },
  {
    "context": [
      "I am looking for a way to reformat a json file, that has line lengths exceeding 2GB, that does not require loading the entire file into memory.",
      "I tried using jq (jq -c . < source.json > output.json ) to compact and format the files. This worked on smaller test files but does not scale. I tried jq's stream function but the process used up memory when rebuilding the structure.",
      "Can this be accomplished with jq?"
    ],
    "utterance": "Reformat a file with line lengths over 2GB into multiple lines, one after each occurrence of a specific key-value pair, without loading the entire file into memory.",
    "expressions": [],
    "identifier": 76477940
  },
  {
    "context": [
      "As part of data preprocessing I need to remove all empty values from an input JSON like empty arrays `[]`, empty objects `{}`, empty strings `\"\"`/`\"   \"`/`\"\\t\"`, objects with empty keys `{\"\":5}` and I need to do that recursively. I also need to trim all the whitespaces of all strings (also if they are object keys). I built a solution using jq 1.6 and a custom `walk()` function. ... I also cast `\"true\"` to boolean `true` and `\"false\"` to boolean `false`.",
      "jq 'walk(      if type == \"string\" then        (sub(\"^[[:space:]]+\"; \"\") | sub(\"[[:space:]]+$\"; \"\") | if . == \"true\" then . |= true else . end | if . == \"false\" then . |= false else . end)      elif type == \"object\" then        with_entries(select(.value | IN(\"\",null, [], {}) | not) | .key |= sub(\"^[[:space:]]+\"; \"\") | .key |= sub(\"[[:space:]]+$\"; \"\") |select(.key | IN(\"\") | not ))      elif type == \"array\" then          map(select(. | IN(\"\",null, [], {}) | not))      else . end)'",
      "How to optimize?  Since you don't seem to have shown the customized version of `walk` you're using, it's hard to say, but here is a more efficient version than the one in builtins.jq:",
      "def walk(f):   def w:     if type == \"object\"     then . as $in    | reduce keys_unsorted[] as $key         ( {}; . + { ($key):  ($in[$key] | w) } ) | f    elif type == \"array\" then map( w ) | f    else f    end;   w;"
    ],
    "utterance": "Recursively remove all empty values (empty arrays, empty objects, empty strings, nulls, and object entries with empty keys), trim whitespace from all strings and object keys, and cast the strings 'true' and 'false' to booleans in all values and keys.",
    "expressions": [
      "walk(\n  if type == \"string\" then\n    (sub(\"^[[:space:]]+\"; \"\") | sub(\"[[:space:]]+$\"; \"\") | if . == \"true\" then . |= true else . end | if . == \"false\" then . |= false else . end)\n  elif type == \"object\" then\n    with_entries(select(.value | IN(\"\",null, [], {}) | not) | .key |= sub(\"^[[:space:]]+\"; \"\") | .key |= sub(\"[[:space:]]+$\"; \"\") | select(.key | IN(\"\") | not ))\n  elif type == \"array\" then\n    map(select(. | IN(\"\",null, [], {}) | not))\n  else . end)"
    ],
    "data": [
      {
        "input": {
          "  key  ": "  true  ",
          "  empty array  ": [],
          "  empty object  ": {},
          "  empty string  ": "",
          "  null  ": null,
          "  nested  ": {
            "  key  ": "  false  ",
            "  empty array  ": [],
            "  empty object  ": {},
            "  empty string  ": "",
            "  null  ": null
          }
        },
        "output": {
          "key": true,
          "nested": {
            "key": false
          }
        }
      }
    ],
    "identifier": 76385616
  },
  {
    "context": [
      "I am trying to get the name and all unique values for the subfield 2 into a output (ideally CSV).",
      "The issue is that the number of fields is not constant and the names of the subfields are not constant either.",
      "jq -rR '\n  split(\"\\t\") \n  | [[.0], \n     ( .[1]|fromjson|.field2.subfield.subfield2 | keys_unsorted|join(\" \"))] \n  | @csv'"
    ],
    "utterance": "Extract the name and all keys at the subfield2 level, where subfield2's keys are dynamic, combining them into a single space-delimited string associated with the name.",
    "expressions": [
      "jq -rR '\n  split(\"\\t\") \n  | [[.0], \n     ( .[1]|fromjson|.field2.subfield.subfield2 | keys_unsorted|join(\" \"))] \n  | @csv'"
    ],
    "data": [
      {
        "input": "name,{\"field1\":{\"name\":\"foo\",\"email\":\"test@gmail.com\"},\"field2\":{\"subfield\":{\"subfield2\":{\"active\":1,\"passive\":11,\"running\":111}}}}",
        "output": "\"name\",\"active passive running\""
      }
    ],
    "identifier": 76477520
  },
  {
    "context": [
      "I have an array of objects that describe software vulnerabilities and want to sort the objects in order by Severity value: CRITICAL, HIGH, MEDIUM, LOW",
      "Create a map from strings to numbers; look up the strings and sort by the resulting numbers.",
      "{ \"CRITICAL\": 0, \"HIGH\": 1, \"MEDIUM\": 2, \"LOW\": 3} as $priority_orders |\n.vulnerabilities | sort_by($priority_orders[.Severity])",
      "You could create a stream of booleans, and sort by that. (Use `!=` for the same order, `==` for reversed order.)",
      ".vulnerabilities |= sort_by(.Severity != (\"CRITICAL\",\"HIGH\",\"MEDIUM\",\"LOW\"))"
    ],
    "utterance": "Sort the vulnerabilities array so that objects are ordered by Severity: CRITICAL first, then HIGH, then MEDIUM, then LOW.",
    "expressions": [
      "{ \"CRITICAL\": 0, \"HIGH\": 1, \"MEDIUM\": 2, \"LOW\": 3} as $priority_orders | .vulnerabilities | sort_by($priority_orders[.Severity])",
      ".vulnerabilities |= sort_by(.Severity != (\"CRITICAL\",\"HIGH\",\"MEDIUM\",\"LOW\"))"
    ],
    "data": [
      {
        "input": {
          "vulnerabilities": [
            {
              "CVEID": "CVE-2022-29458",
              "Product": "ncurses-base",
              "Severity": "MEDIUM",
              "Version": "6.3-2",
              "Description": "example"
            },
            {
              "CVEID": "CVE-2022-29458",
              "Product": "ncurses-base",
              "Severity": "HIGH",
              "Version": "6.3-2",
              "Description": "example"
            },
            {
              "CVEID": "CVE-2022-29458",
              "Product": "ncurses-base",
              "Severity": "CRITICAL",
              "Version": "6.3-2",
              "Description": "example"
            },
            {
              "CVEID": "CVE-2022-29458",
              "Product": "ncurses-base",
              "Severity": "LOW",
              "Version": "6.3-2",
              "Description": "example"
            }
          ]
        },
        "output": [
          {
            "CVEID": "CVE-2022-29458",
            "Product": "ncurses-base",
            "Severity": "CRITICAL",
            "Version": "6.3-2",
            "Description": "example"
          },
          {
            "CVEID": "CVE-2022-29458",
            "Product": "ncurses-base",
            "Severity": "HIGH",
            "Version": "6.3-2",
            "Description": "example"
          },
          {
            "CVEID": "CVE-2022-29458",
            "Product": "ncurses-base",
            "Severity": "MEDIUM",
            "Version": "6.3-2",
            "Description": "example"
          },
          {
            "CVEID": "CVE-2022-29458",
            "Product": "ncurses-base",
            "Severity": "LOW",
            "Version": "6.3-2",
            "Description": "example"
          }
        ]
      }
    ],
    "identifier": 76476166
  },
  {
    "context": [
      "Sample input data:",
      "{\n\t\"kind\": \"TOTP\",\n\t\"account\": \"google@gmail.com\",\n\t\"secret\": \"GoogleSecret\",\n\t\"iconType\": \"raivo_repository\",\n\t\"issuer\": \"Google.com\",\n\t\"timer\": \"30\",\n\t\"digits\": \"6\",\n\t\"counter\": \"0\",\n\t\"algorithm\": \"SHA1\",\n\t\"iconValue\": \"google.com/google-gmail.png\"\n},",
      "I'd like the output to look like this:",
      "{\n\t\"type\": \"totp\",\n\t\"uuid\": \"b33ca6f5-7661-4289-afcc-ee9847c3e59a\",\n\t\"name\": \"google@gmail.com\",\n\t\"issuer\": \"Google.com\",\n\t\"note\": \"\",\n\t\"icon\": null,\n\t\"info\": {\n\t  \"secret\": \"GoogleSecret\",\n\t  \"algo\": \"SHA1\",\n\t  \"digits\": 6,\n\t  \"period\": 30\n\t}\n}",
      "If you just want to translate certain keys to certain other keys (with slight modifications sometimes), just create a new object, and assign the corresponding values (I didn't get where `uuid` is supposed to come from):",
      "{\n  type: .kind | ascii_downcase,\n  uuid: \"???\",\n  name: .account,\n  issuer,\n  note: \"\",\n  icon: null,\n  info: {\n    secret,\n    algo: .algorithm,\n    digits: .digits | tonumber,\n    period: .timer | tonumber\n  }\n}"
    ],
    "utterance": "Transform an object with fields like 'kind', 'account', 'secret', 'algorithm', 'digits', and 'timer' into an object with relabelled and nested fields, including an 'info' object with specific numeric conversions.",
    "expressions": [
      "{\n  type: .kind | ascii_downcase,\n  uuid: \"???\",\n  name: .account,\n  issuer,\n  note: \"\",\n  icon: null,\n  info: {\n    secret,\n    algo: .algorithm,\n    digits: .digits | tonumber,\n    period: .timer | tonumber\n  }\n}"
    ],
    "data": [
      {
        "input": {
          "kind": "TOTP",
          "account": "google@gmail.com",
          "secret": "GoogleSecret",
          "iconType": "raivo_repository",
          "issuer": "Google.com",
          "timer": "30",
          "digits": "6",
          "counter": "0",
          "algorithm": "SHA1",
          "iconValue": "google.com/google-gmail.png"
        },
        "output": {
          "type": "totp",
          "uuid": "???",
          "name": "google@gmail.com",
          "issuer": "Google.com",
          "note": "",
          "icon": null,
          "info": {
            "secret": "GoogleSecret",
            "algo": "SHA1",
            "digits": 6,
            "period": 30
          }
        }
      }
    ],
    "identifier": 76479372
  },
  {
    "context": [
      "I want to convert each of the files I have into a list of objects that captures the `title`, list of `id` and list of `name` in a single object:",
      "{\n  \"title\": \"Some more data\",\n  \"ids\": [\n      \"123\",\n      \"abc\"\n  ],\n  \"names\": [\n      \"A\",\n      \"B\"\n  ]\n}",
      "You could iterate over the outer array using `.[]`, then construct the objects using `? //` to provide alternatives if one evaluates to `null`.",
      ".[] | {title} + (.data | {\n  ids: map(.ids[]? // . | .id),\n  names: map(.names[]? // . | .name)\n})",
      ".[] | {title} + (.data | {\n  ids: map(.ids[]? // . | .id | values),\n  names: map(.names[]? // . | .name | values)\n})",
      ".[] | {title} + (.data | {\n  ids: map(.ids[]? // . | .id | values),\n  names: map(.names[]? // . | .name | values)\n} | map_values(select(. != [])))",
      "{ title }\n+ (.data | {\n    ids: map(.ids[].id),\n    names: (map(.names[].name)? // []) # or // null\n})",
      "{\n    title,\n    ids: (.data | map(.ids[].id)),\n    names: (.data | map(.names[].name)? // [])\n}"
    ],
    "utterance": "Convert each object to one containing the title, a list of all id values, and a list of all name values, combining data from both formats into a unified structure.",
    "expressions": [
      ".[] | {title} + (.data | {ids: map(.ids[]? // . | .id), names: map(.names[]? // . | .name)})",
      ".[] | {title} + (.data | {ids: map(.ids[]? // . | .id | values), names: map(.names[]? // . | .name | values)})",
      ".[] | {title} + (.data | {ids: map(.ids[]? // . | .id | values), names: map(.names[]? // . | .name | values)} | map_values(select(. != [])))",
      "{ title } + (.data | { ids: map(.ids[].id), names: (map(.names[].name)? // []) })",
      "{ title, ids: (.data | map(.ids[].id)), names: (.data | map(.names[].name)? // []) }"
    ],
    "data": [
      {
        "input": [
          {
            "title": "Some data",
            "data": [
              {
                "id": "123"
              },
              {
                "id": "abc"
              }
            ]
          },
          {
            "title": "Some more data",
            "data": [
              {
                "ids": [
                  {
                    "id": "123"
                  },
                  {
                    "id": "abc"
                  }
                ],
                "names": [
                  {
                    "name": "A"
                  },
                  {
                    "name": "B"
                  }
                ]
              }
            ]
          }
        ],
        "output": [
          {
            "title": "Some data",
            "ids": [
              "123",
              "abc"
            ],
            "names": []
          },
          {
            "title": "Some more data",
            "ids": [
              "123",
              "abc"
            ],
            "names": [
              "A",
              "B"
            ]
          }
        ]
      }
    ],
    "identifier": 76404598
  },
  {
    "context": [
      "and i want just some properties like: id, satus, total and from billing first_name.",
      "How do i geht the first name from billing array?",
      "map({id, status, total, first_name: .billing.first_name})"
    ],
    "utterance": "Extract the id, status, total, and the billing object's first_name for each item in the array.",
    "expressions": [
      "map({id, status, total, first_name: .billing.first_name})"
    ],
    "data": [
      {
        "input": [
          {
            "id": 727,
            "parent_id": 0,
            "number": "727",
            "order_key": "wc_order_58d2d042d1d",
            "created_via": "rest-api",
            "version": "3.0.0",
            "status": "processing",
            "currency": "USD",
            "date_created": "2017-03-22T16:28:02",
            "date_created_gmt": "2017-03-22T19:28:02",
            "date_modified": "2017-03-22T16:28:08",
            "date_modified_gmt": "2017-03-22T19:28:08",
            "discount_total": "0.00",
            "discount_tax": "0.00",
            "shipping_total": "10.00",
            "shipping_tax": "0.00",
            "cart_tax": "1.35",
            "total": "29.35",
            "total_tax": "1.35",
            "prices_include_tax": false,
            "customer_id": 0,
            "customer_ip_address": "",
            "customer_user_agent": "",
            "customer_note": "",
            "billing": {
              "first_name": "John",
              "last_name": "Doe",
              "company": ""
            }
          }
        ],
        "output": [
          {
            "id": 727,
            "status": "processing",
            "total": "29.35",
            "first_name": "John"
          }
        ]
      }
    ],
    "identifier": 76505533
  },
  {
    "context": [
      "aws ecr list-images --repository-name plat   | jq '.imageIds   | map (.imageTag)  | sort | .[]'   | sort -r   | head -1",
      "aws ecr list-images --repository-name plat | jq '.imageIds | map (.imageTag)|sort|.[]' | sort -r | head -1",
      "{\n    \"imageIds\": [\n        {\n            \"imageDigest\": \"sha256:5fd06c0b6c6349324343232432429e8bf6b1ce62d810c2eef1eca\",\n            \"imageTag\": \"20230421.001\"\n        },\n        {\n            \"imageDigest\": \"sha256:d7a28e9e62c5465465465469080eeae6a8308c99ec032a845119202f6d427ef8\",\n            \"imageTag\": \"33345.1\"\n        },\n        {\n            \"imageDigest\": \"sha256:681ae17a52a4c673cc8c62d50823432432432432432432497789879c37a4\",\n            \"imageTag\": \"3445.2\"\n        },\n        {\n            \"imageDigest\": \"sha256:ff7090d214ac72334323243209809809803e8af\",\n            \"imageTag\": \"33456.1\"\n        }\n]\n}",
      "powershell.exe aws ecr list-images --repository-name <repo-name> | jq '.imageIds | map (.imageTag) | sort | reverse | first'\""
    ],
    "utterance": "Get the most recent imageTag value from the list of imageIds returned for the plat repository.",
    "expressions": [
      ".imageIds | map(.imageTag) | sort | reverse | first",
      ".imageIds | map(.imageTag) | sort | last"
    ],
    "data": [
      {
        "input": {
          "imageIds": [
            {
              "imageDigest": "sha256:5fd06c0b6c6349324343232432429e8bf6b1ce62d810c2eef1eca",
              "imageTag": "20230421.001"
            },
            {
              "imageDigest": "sha256:d7a28e9e62c5465465465469080eeae6a8308c99ec032a845119202f6d427ef8",
              "imageTag": "33345.1"
            },
            {
              "imageDigest": "sha256:681ae17a52a4c673cc8c62d50823432432432432432432497789879c37a4",
              "imageTag": "3445.2"
            },
            {
              "imageDigest": "sha256:ff7090d214ac72334323243209809809803e8af",
              "imageTag": "33456.1"
            }
          ]
        },
        "output": "33345.1"
      }
    ],
    "identifier": 76482895
  },
  {
    "context": [
      "I want to define a subset of fields that I want to extract and move into a new sub-object with a specific name.",
      "`{ alpha, epsilon: { beta, delta }, gamma }`",
      "Here's a programmatic way:",
      "jq --argjson fields '[\"beta\", \"delta\"]' '\n def project($fields): . as $in | reduce $fields[] as $k ({}; .[$k] = $in[$k]);\n\n .epsilon = project($fields)\n | delpaths( [$fields[]| [.]] )\n '"
    ],
    "utterance": "Move the fields named 'beta' and 'delta' from the top level into a new sub-object 'epsilon', preserving the other fields.",
    "expressions": [
      "{ alpha, epsilon: { beta, delta }, gamma }",
      "def project($fields): . as $in | reduce $fields[] as $k ({}; .[$k] = $in[$k]);\n\n.epsilon = project($fields) | delpaths([$fields[]|[.]])"
    ],
    "data": [
      {
        "input": {
          "alpha": "...",
          "beta": [
            1,
            2,
            3
          ],
          "delta": {
            "x": 1
          },
          "gamma": "..."
        },
        "output": {
          "alpha": "...",
          "epsilon": {
            "beta": [
              1,
              2,
              3
            ],
            "delta": {
              "x": 1
            }
          },
          "gamma": "..."
        }
      }
    ],
    "identifier": 76510577
  },
  {
    "context": [
      "The need is to **specify the attributes to be kept**, instead : e.g.  {children,type,root,title,uri}.",
      "As output, the whole JSON hierarchy has to be preserved.",
      "You could `walk` through the structure, and update all `objects` by using `with_entries` to temporarily convert them into an array of key-value pairs, and filter them for those entries with matching keys (i.e. `select` it if its `.key` is `IN` a given list of positives).\n```\nwalk(objects |= with_entries(select(IN(.key;\n  \"children\", \"type\", \"root\", \"title\", \"uri\"\n))))\n```"
    ],
    "utterance": "Retain only the attributes children, type, root, title, and uri at all levels, preserving the entire hierarchy.",
    "expressions": [
      "walk(objects |= with_entries(select(IN(.key; \"children\", \"type\", \"root\", \"title\", \"uri\"))))"
    ],
    "data": [
      {
        "input": {
          "guid": "toolbar_____",
          "title": "toolbar",
          "type": "text/x-moz-place-container",
          "children": [
            {
              "guid": "Y-lVXPFXlF15",
              "title": "",
              "iconUri": "https://fr.wikipedia.org/static/apple-touch/wikipedia.png",
              "type": "text/x-moz-place",
              "uri": "https://fr.wikipedia.org/"
            },
            {
              "guid": "S7ow_jYLOBlX",
              "title": "tmp",
              "type": "text/x-moz-place-container",
              "children": [
                {
                  "guid": "IFQ7EJXc-eNH",
                  "title": "Logiciel Attentes",
                  "type": "text/x-moz-place-container",
                  "children": [
                    {
                      "guid": "l-CtLEfkIatC",
                      "title": "LMMS v122",
                      "iconUri": "https://lmms.io/img/logo_sm.png",
                      "type": "text/x-moz-place",
                      "uri": "https://lmms.io/download#collapse_linpre"
                    },
                    {
                      "guid": "a5HfcSy3k_sT",
                      "title": "Slax UEFI apres v9.11",
                      "type": "text/x-moz-place",
                      "uri": "https://www.slax.org/"
                    }
                  ]
                },
                {
                  "guid": "FUt5BsHdDl2Y",
                  "title": "Firewalls \u2013 MX Linux",
                  "type": "text/x-moz-place",
                  "uri": "https://mxlinux.org/wiki/networking/firewalls/"
                }
              ]
            }
          ]
        },
        "output": {
          "title": "toolbar",
          "type": "text/x-moz-place-container",
          "children": [
            {
              "title": "",
              "type": "text/x-moz-place",
              "uri": "https://fr.wikipedia.org/"
            },
            {
              "title": "tmp",
              "type": "text/x-moz-place-container",
              "children": [
                {
                  "title": "Logiciel Attentes",
                  "type": "text/x-moz-place-container",
                  "children": [
                    {
                      "title": "LMMS v122",
                      "type": "text/x-moz-place",
                      "uri": "https://lmms.io/download#collapse_linpre"
                    },
                    {
                      "title": "Slax UEFI apres v9.11",
                      "type": "text/x-moz-place",
                      "uri": "https://www.slax.org/"
                    }
                  ]
                },
                {
                  "title": "Firewalls \u2013 MX Linux",
                  "type": "text/x-moz-place",
                  "uri": "https://mxlinux.org/wiki/networking/firewalls/"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 76493615
  },
  {
    "context": [
      "How could I get a list of objects looking like:\r\n\r\n```\r\n[\r\n{\r\n  'column 1': 'foo',\r\n  'column 2': 'bar'\r\n},\r\n{\r\n  'column 1': 'foo1',\r\n  'column 2': 'bar1'\r\n}\r\n```",
      "jq '\r\n  (.columns | map({(.id | tostring): .title}) | add) as $columnTitles\r\n  | .rows | map(\r\n      .cells | map({($columnTitles[.columnId | tostring]): .value}) | add\r\n    )\r\n' file.json",
      "INDEX(.columns[]; .id) as $map | .rows | map(\r\n  .cells | map({($map.\"\\(.columnId)\".title): .value}) | add\r\n)\r\n"
    ],
    "utterance": "Produce a list where each object maps column titles to their corresponding cell values for each row.",
    "expressions": [
      "(.columns | map({(.id | tostring): .title}) | add) as $columnTitles | .rows | map(.cells | map({($columnTitles[.columnId | tostring]): .value}) | add)",
      "INDEX(.columns[]; .id) as $map | .rows | map(.cells | map({($map.\"\\(.columnId)\".title): .value}) | add)"
    ],
    "data": [
      {
        "input": {
          "columns": [
            {
              "id": 123,
              "title": "column 1"
            },
            {
              "id": 456,
              "title": "column 2"
            }
          ],
          "rows": [
            {
              "cells": [
                {
                  "columnId": 123,
                  "value": "foo"
                },
                {
                  "columnId": 456,
                  "value": "bar"
                }
              ]
            },
            {
              "cells": [
                {
                  "columnId": 123,
                  "value": "foo1"
                },
                {
                  "columnId": 456,
                  "value": "bar1"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "column 1": "foo",
            "column 2": "bar"
          },
          {
            "column 1": "foo1",
            "column 2": "bar1"
          }
        ]
      }
    ],
    "identifier": 76535204
  },
  {
    "context": [
      "need to create new key using `jq` via merging outer key with inner key and setting their value same as inner key value.",
      "Expected output:\nES_HOST=\"https://es-host.ap-south-1.es.amazonaws.com\"\nES_USER=\"es_admin\"\nES_PASS=\"pa$$w0rd\"\n\nDB_HOST=\"https://db-host.ap-south-1.es.amazonaws.com\"\nDB_USER=\"db_admin\"\nDB_PASS=\"pa$$w0rd\"",
      "jq -r '\n  paths(strings) as $path\n  | \"\\($path | map(ascii_upcase) | join(\"_\"))=\\(getpath($path) | @json)\"\n'",
      "jq -r '\n  to_entries[] | \"\\(.key | ascii_upcase)_\\(.value\n    | to_entries[] | \"\\(.key | ascii_upcase)=\\(.value | @json)\"\n  )\"\n'"
    ],
    "utterance": "Create new text keys by combining each top-level key with each inner key, separated by an underscore and capitalized, with the value being the corresponding inner value.",
    "expressions": [
      "paths(strings) as $path | \"\\($path | map(ascii_upcase) | join(\"_\"))=\\(getpath($path) | @json)\"",
      "to_entries[] | \"\\(.key | ascii_upcase)_\\(.value | to_entries[] | \"\\(.key | ascii_upcase)=\\(.value | @json)\" )\""
    ],
    "data": [
      {
        "input": {
          "es": {
            "host": "https://es-host.ap-south-1.es.amazonaws.com",
            "user": "es_admin",
            "pass": "pa$$w0rd"
          },
          "db": {
            "host": "https://db-host.ap-south-1.es.amazonaws.com",
            "user": "db_admin",
            "pass": "pa$$w0rd"
          }
        },
        "output": "ES_HOST=\"https://es-host.ap-south-1.es.amazonaws.com\"\nES_USER=\"es_admin\"\nES_PASS=\"pa$$w0rd\"\nDB_HOST=\"https://db-host.ap-south-1.es.amazonaws.com\"\nDB_USER=\"db_admin\"\nDB_PASS=\"pa$$w0rd\""
      }
    ],
    "identifier": 76536090
  },
  {
    "context": [
      "Basically what I am looking to do is have the data come out looking like this with a MITRE and NIST URL built based on the \"CVEID\" value:",
      "`|=` can be used to replace an element with a new value without deleting prior parts of the tree. Thus, consider:",
      ".vulnerabilities |= map(\n  if .CVEID? != null then\n    . + {MITRE_URL: \"\\($MITRE_URL)\\(.CVEID)\",\n         NIST_URL:  \"\\($NIST_URL)\\(.CVEID)\"}\n  else . end\n)"
    ],
    "utterance": "Add MITRE_URL and NIST_URL fields to each vulnerability object using the value of its CVEID field.",
    "expressions": [
      ".vulnerabilities |= map(if .CVEID? != null then . + {MITRE_URL: \"\\($MITRE_URL)\\(.CVEID)\", NIST_URL: \"\\($NIST_URL)\\(.CVEID)\"} else . end)"
    ],
    "data": [
      {
        "input": {
          "count": 2,
          "os": "Debian GNU 11",
          "vulnerabilities": [
            {
              "CVEID": "CVE-2023-29491",
              "Product": "ncurses-base",
              "Severity": "HIGH",
              "Version": "6.2+20201114-2+deb11u1",
              "Description": "ncurses before 6.4 20230408, when used by a setuid application, allows local users to trigger security-relevant memory corruption via malformed data in a terminfo database file that is found in $HOME/.terminfo or reached via the TERMINFO or TERM environment variable.\n"
            },
            {
              "CVEID": "CVE-2022-29458",
              "Product": "ncurses-base",
              "Severity": "HIGH",
              "Version": "6.2+20201114-2+deb11u1",
              "Description": "ncurses 6.3 before patch 20220416 has an out-of-bounds read and segmentation violation in convert_strings in tinfo/read_entry.c in the terminfo library.\n"
            }
          ]
        },
        "output": {
          "count": 2,
          "os": "Debian GNU 11",
          "vulnerabilities": [
            {
              "CVEID": "CVE-2023-29491",
              "Product": "ncurses-base",
              "Severity": "HIGH",
              "Version": "6.2+20201114-2+deb11u1",
              "Description": "ncurses before 6.4 20230408, when used by a setuid application, allows local users to trigger security-relevant memory corruption via malformed data in a terminfo database file that is found in $HOME/.terminfo or reached via the TERMINFO or TERM environment variable.\n",
              "MITRE_URL": "https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2023-29491",
              "NIST_URL": "https://nvd.nist.gov/vuln/detail/CVE-2023-29491"
            },
            {
              "CVEID": "CVE-2022-29458",
              "Product": "ncurses-base",
              "Severity": "HIGH",
              "Version": "6.2+20201114-2+deb11u1",
              "Description": "ncurses 6.3 before patch 20220416 has an out-of-bounds read and segmentation violation in convert_strings in tinfo/read_entry.c in the terminfo library.\n",
              "MITRE_URL": "https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2022-29458",
              "NIST_URL": "https://nvd.nist.gov/vuln/detail/CVE-2022-29458"
            }
          ]
        }
      }
    ],
    "identifier": 76526793
  },
  {
    "context": [
      "The final part I need to do is select only entries where result = \"succeeded\".",
      "```\njq '[.value[] | select(.result=\"succeeded\") | {id: .id, date: .finishedDate, state: .state, result: .result}] | sort_by(.finishedDate)'\n```",
      "map(select(.result==\"succeeded\") | { id, date: .finishedDate, state, result }) | sort_by(.date)",
      "* The `select()` needs to be inside the `map()`",
      "* `sort_by()` after the `select()` so we don't need to sort those we're removing"
    ],
    "utterance": "Extract all entries with result equal to \"succeeded\", include only the id, finishedDate as date, state, and result fields, and sort the output by date.",
    "expressions": [
      ".value | map(select(.result==\"succeeded\") | { id, date: .finishedDate, state, result }) | sort_by(.date)"
    ],
    "data": [
      {
        "input": {
          "value": [
            {
              "id": 1902,
              "finishedDate": "2023-06-19T13:08:17.6903656Z",
              "state": "completed",
              "result": "succeeded"
            },
            {
              "id": 1668,
              "finishedDate": "2023-06-19T13:00:18.9255899Z",
              "state": "completed",
              "result": "failed"
            },
            {
              "id": 1621,
              "finishedDate": "2023-06-14T12:11:10.2714172Z",
              "state": "completed",
              "result": "failed"
            },
            {
              "id": 1569,
              "finishedDate": "2023-06-14T08:20:34.0988263Z",
              "state": "completed",
              "result": "succeeded"
            },
            {
              "id": 1566,
              "finishedDate": "2023-06-14T08:29:32.1229317Z",
              "state": "completed",
              "result": "succeeded"
            },
            {
              "id": 1564,
              "finishedDate": "2023-06-14T07:48:54.1384016Z",
              "state": "completed",
              "result": "failed"
            },
            {
              "id": 1557,
              "finishedDate": "2023-06-14T07:36:16.8346765Z",
              "state": "completed",
              "result": "succeeded"
            },
            {
              "id": 1555,
              "finishedDate": "2023-06-14T07:24:19.5030833Z",
              "state": "completed",
              "result": "failed"
            },
            {
              "id": 1553,
              "finishedDate": "2023-06-14T07:11:50.4071939Z",
              "state": "completed",
              "result": "failed"
            },
            {
              "id": 1551,
              "finishedDate": "2023-06-14T06:58:34.3160857Z",
              "state": "completed",
              "result": "failed"
            }
          ]
        },
        "output": [
          {
            "id": 1557,
            "date": "2023-06-14T07:36:16.8346765Z",
            "state": "completed",
            "result": "succeeded"
          },
          {
            "id": 1569,
            "date": "2023-06-14T08:20:34.0988263Z",
            "state": "completed",
            "result": "succeeded"
          },
          {
            "id": 1566,
            "date": "2023-06-14T08:29:32.1229317Z",
            "state": "completed",
            "result": "succeeded"
          },
          {
            "id": 1902,
            "date": "2023-06-19T13:08:17.6903656Z",
            "state": "completed",
            "result": "succeeded"
          }
        ]
      }
    ],
    "identifier": 76524798
  },
  {
    "context": [
      "Let\u2019s assume I had a json doc like this:\n{\n  \"counts\": [\n    17,\n    1014,\n    22,\n    9,\n    11\n  ],\n  \"values\": [\n    \"5\",\n    \"10\",\n    \"15\",\n    \"20\",\n    \"25\"\n  ]\n}\nand I wanted to get a result like this:\n{\n    \"5\":17,\n    \"10\":1014,\n    \"15\":22,\n    \"20\":9,\n    \"25\":11\n}",
      "[ .counts, .values ] | transpose | reduce .[] as $t ({}; .[$t[1]] = $t[0])",
      "[(.counts | keys[]) as $i | {(.values[$i]): .counts[$i]}] | add",
      ". as {$values} | .counts | with_entries(.key |= $values[.])",
      ". as $in | reduce (.values|keys[]) as $i ({}; .[$in.values[$i]] = $in.counts[$i])"
    ],
    "utterance": "Combine two arrays of equal length into an object with one array providing the keys and the other providing the values.",
    "expressions": [
      "[ .counts, .values ] | transpose | reduce .[] as $t ({}; .[$t[1]] = $t[0])",
      "[(.counts | keys[]) as $i | {(.values[$i]): .counts[$i]}] | add",
      ". as {$values} | .counts | with_entries(.key |= $values[.])",
      ". as $in | reduce (.values|keys[]) as $i ({}; .[$in.values[$i]] = $in.counts[$i])"
    ],
    "data": [
      {
        "input": {
          "counts": [
            17,
            1014,
            22,
            9,
            11
          ],
          "values": [
            "5",
            "10",
            "15",
            "20",
            "25"
          ]
        },
        "output": {
          "5": 17,
          "10": 1014,
          "15": 22,
          "20": 9,
          "25": 11
        }
      }
    ],
    "identifier": 76563529
  },
  {
    "context": [
      "The command is `jq -r '.version |= \"${TAG}\"' temp.json > package.json` but the ${TAG} or $TAG is not resolving to its value.",
      "For using a bash-variable in jq's filter you need to bind the variable as argument e.g. `--arg name $variable`",
      "In your case you could write following.",
      "jq -r --arg TEMP_TAG \"$TAG\" '.version |= \"$TEMP_TAG\"' temp.json > package.json"
    ],
    "utterance": "Update the version field to the value of the TAG environment variable.",
    "expressions": [
      "jq -r --arg TEMP_TAG \"$TAG\" '.version |= \"$TEMP_TAG\"' temp.json > package.json"
    ],
    "identifier": 76583083
  },
  {
    "context": [
      "I have the following json : ... In bash, I'm trying to extract the `password_clear` value when the `username` matches my variable.",
      "jq -r --arg user \"PRODUCTION_1\" \\\n  '.[] | select(.username? == $user).password_clear' file.json",
      "Output:\n7bla1234"
    ],
    "utterance": "Extract the password_clear value for the entry whose username is PRODUCTION_1.",
    "expressions": [
      ".[] | select(.username? == $user).password_clear"
    ],
    "data": [
      {
        "input": {
          "id": "jboss_data1",
          "DS1": {
            "policy_name": "CAT_LOCATION",
            "username": "PRODUCTION_1",
            "password_clear": "7bla1234"
          },
          "DS3": {
            "policy_name": "CAT_SRC",
            "username": "PRODUCTION_2",
            "password_clear": "foo7864"
          },
          "DS4": {
            "policy_name": "CAT_FOLDER",
            "username": "PRODUCTION_3",
            "password_clear": "123bar456"
          }
        },
        "output": "7bla1234"
      }
    ],
    "identifier": 76580033
  },
  {
    "context": [
      "a='[{\"a\":\"b\"},{\"c\":\"d c\"}]'",
      "b=\"d c\"",
      "echo $a|jq '.[]|select(.c == \"$b\")'",
      "There is a space in the value of `$b`. Thus, when expanded you end up with two arguments to jq, one being `.[]|select(.c == \"d` and the other one being `c\")`.",
      "If you wanted to properly inject the variable with whitespace, quote the shell variable(s):",
      "echo \"$a\" | jq '.[]|select(.c == \"'$b'\")'",
      "Better yet, don't inject data into code, use the idiomatic way to import strings into jq with the dedicated `--arg` option:",
      "echo \"$a\" | jq --arg b \"$b\"  '.[]|select(.c == $b)'"
    ],
    "utterance": "Select all objects where the value of the field c is exactly 'd c', handling cases where the match value contains spaces.",
    "expressions": [
      ".[]|select(.c == \"$b\")",
      ".[]|select(.c == $b)"
    ],
    "data": [
      {
        "input": [
          {
            "a": "b"
          },
          {
            "c": "d c"
          }
        ],
        "output": {
          "c": "d c"
        }
      }
    ],
    "identifier": 76565692
  },
  {
    "context": [
      "1. The JSON must contain a single object",
      "2. All keys shall be named like shell variables",
      "3. All values must be scalars",
      "4. No `NUL` byte in values",
      "def valid_key: test(\"^[A-Za-z_][0-9A-Za-z_]*$\");",
      "def valid_value:\n    type != \"array\" and type != \"object\" and (\n        type != \"string\" or (test(\"\\u0000\") | not)\n    );",
      "def valid_input:\n    type == \"object\" and (\n        to_entries | all(\n            (.key | valid_key) and (.value | valid_value)\n        )\n    );",
      "input |\n    if valid_input and isempty(inputs) then\n        to_entries[] | \"\\(.key)=\\(.value | @sh)\"\n    else\n        \"bad input\\n\" | halt_error(1)\n    end",
      "if type != \"object\" then \"\\(@json) is not an object (#1)\"",
      "if .key | test(\"\\\\A[_a-zA-Z]\\\\w*\\\\z\") | not then \"\\(.key | @json) is illegal (#2)\"",
      "if isempty(scalars) then \"\\(.) is not a scalar (#3)\"",
      "if test(\"\\u0000\") then \"\\(.[index(\"\\u0000\")+1:] | @json) is preceded by NUL (#4)\""
    ],
    "utterance": "Validate that the input contains exactly one object in which all keys follow shell variable naming conventions, all values are scalars, and string values do not contain NUL bytes; otherwise, return an error.",
    "expressions": [
      "jq -nr '\ndef valid_key: test(\"^[A-Za-z_][0-9A-Za-z_]*$\");\ndef valid_value:\n    type != \"array\" and type != \"object\" and (\n        type != \"string\" or (test(\"\\u0000\") | not)\n    );\ndef valid_input:\n    type == \"object\" and (\n        to_entries | all(\n            (.key | valid_key) and (.value | valid_value)\n        )\n    );\ninput |\n    if valid_input and isempty(inputs) then\n        to_entries[] | \"\\(.key)=\\(.value | @sh)\"\n    else\n        \"bad input\\n\" | halt_error(1)\n    end'"
    ],
    "data": [
      {
        "input": {
          "\"\"": "empty key shall fail",
          "illegal key shall fail": "keys shall follow the naming convention of shell variables",
          "non_scalar_shall_fail_1": [
            1,
            2
          ],
          "non_scalar_shall_fail_2": {
            "k": "v"
          },
          "nul_byte_shall_fail": "file.php\u0000.txt"
        },
        "output": "bad input\n"
      },
      {
        "input": {
          "task_uuid": "5d7ea654-b649-452b-a8fd-002b56be9a59",
          "task_name": "hello world",
          "user_email": null,
          "min": 7,
          "max": 100,
          "ave": 2.5,
          "file_in": "data.txt",
          "file_out": "results.txt"
        },
        "output": [
          "task_uuid='5d7ea654-b649-452b-a8fd-002b56be9a59'",
          "task_name='hello world'",
          "user_email=null",
          "min=7",
          "max=100",
          "ave=2.5",
          "file_in='data.txt'",
          "file_out='results.txt'"
        ]
      }
    ],
    "identifier": 76481941
  },
  {
    "context": [
      "I want to select an item from array and update as below",
      "jq '(.first | .second[] | select(.third | index(\"1002\")) | .fourth) |= \"changed\"' temp.json",
      "Workaround: Wrap the body in parens, and compare its result against `null` to get a boolean:",
      "(.first | .second[] | select((.third | index(\"1002\")) != null) | .fourth) = \"changed\""
    ],
    "utterance": "Set the value of 'fourth' to 'changed' for each object in 'first.second' where the array 'third' contains the string '1002'.",
    "expressions": [
      "(.first | .second[] | select((.third | index(\"1002\")) != null) | .fourth) = \"changed\""
    ],
    "data": [
      {
        "input": {
          "first": {
            "second": [
              {
                "third": [
                  "1000",
                  "1001"
                ],
                "fourth": "Don'tWantToChange"
              },
              {
                "third": [
                  "1000",
                  "1001",
                  "1002"
                ],
                "fourth": "WantToChange"
              }
            ]
          }
        },
        "output": {
          "first": {
            "second": [
              {
                "third": [
                  "1000",
                  "1001"
                ],
                "fourth": "Don'tWantToChange"
              },
              {
                "third": [
                  "1000",
                  "1001",
                  "1002"
                ],
                "fourth": "changed"
              }
            ]
          }
        }
      }
    ],
    "identifier": 76583318
  },
  {
    "context": [
      "In the above example, given the arguments of --arg a '\"1\"' --arg b '\"2\"', I have to manually add \"a\" and \"b\" to the template (the string from stdin). This duplication is not desirable.",
      "How can I make the template independent of the arguments to be passed?",
      "You can use $ARGS.named :",
      "jq -c -n -f /dev/stdin --arg a '\"1\"' --arg b '\"2\"' <<<'{u: \"u\"} + $ARGS.named'"
    ],
    "utterance": "Merge fixed key-value pairs with all command-line arguments so that keys specified in arguments are added automatically, avoiding the need to manually list them in the object template.",
    "expressions": [
      "{u: \"u\"} + $ARGS.named"
    ],
    "data": [
      {
        "input": {
          "u": "u",
          "a": "\"1\"",
          "b": "\"2\""
        },
        "output": {
          "u": "u",
          "a": "\"1\"",
          "b": "\"2\""
        }
      }
    ],
    "identifier": 76599435
  },
  {
    "context": [
      "I'm trying to get the keys named `key2` which has the value `\"\"` from a JSON file as below through `jq`.",
      "Use [`to_entries`](https://jqlang.github.io/jq/manual/#to_entries,from_entries,with_entries(f)) to get an array of key-value-pairs, then iterate it with [`.[]`](https://jqlang.github.io/jq/manual/#Array/ObjectValueIterator:.[]) it and [`select`](https://jqlang.github.io/jq/manual/#select(boolean_expression)) the pairs with an empty value, and finally extract the [`.key`](https://jqlang.github.io/jq/manual/#ObjectIdentifier-Index:.foo,.foo.bar) from the pair:",
      "to_entries[] | select(.value==\"\") | .key",
      "Output:",
      "\"key2\""
    ],
    "utterance": "Find the keys whose value is an empty string.",
    "expressions": [
      "to_entries[] | select(.value==\"\") | .key"
    ],
    "data": [
      {
        "input": {
          "Key": "value",
          "key1": "value1",
          "key2": ""
        },
        "output": "key2"
      }
    ],
    "identifier": 76603465
  },
  {
    "context": [
      "I want to change the state to \"disabled\" based on the filtered IP address range(eg \"10.13*\").",
      "jq '(.[]| select(.node|test(\"^10.13*\"))).state |=\"disabled\" data.json",
      "Your regex isn\u2019t quite right. Also, it might be worthwhile using `map` to make things more straightforward:",
      "map(if (.node|test(\"^10[.]13[.]\") ) then .state=\"disabled\" else . end)",
      "If you only want to modify array elements whose IP address starts with \"10.13.\", you'd usually use `map` and combine with `startswith` (for prefix-matching the IP address):",
      "jq 'map(select(.node|startswith(\"10.13.\")).state = \"disabled\")' input.json",
      "jq '(.[]|select(.node|startswith(\"10.13\")).state) = \"disabled\"' input.json"
    ],
    "utterance": "Set the state field to \"disabled\" for all objects where node starts with \"10.13\" while returning the entire modified data.",
    "expressions": [
      "map(if (.node|test(\"^10[.]13[.]\") ) then .state=\"disabled\" else . end)",
      "map(select(.node|startswith(\"10.13.\")).state = \"disabled\")",
      "(.[]|select(.node|startswith(\"10.13\")).state) = \"disabled\""
    ],
    "data": [
      {
        "input": [
          {
            "node": "10.13.248.254:61052",
            "state": "active"
          },
          {
            "node": "10.13.248.255:61052",
            "state": "active"
          },
          {
            "node": "10.54.247.228:61052",
            "state": "active"
          },
          {
            "node": "10.54.247.229:61052",
            "state": "active"
          }
        ],
        "output": [
          {
            "node": "10.13.248.254:61052",
            "state": "disabled"
          },
          {
            "node": "10.13.248.255:61052",
            "state": "disabled"
          },
          {
            "node": "10.54.247.228:61052",
            "state": "active"
          },
          {
            "node": "10.54.247.229:61052",
            "state": "active"
          }
        ]
      }
    ],
    "identifier": 76570156
  },
  {
    "context": [
      "I'd like to uppercase the first letter over every property name, recursively.",
      "Desired Output:",
      "{ \"Field1\": \"v1\", \"Field2\": { \"Subfield1\": \"sv1\" }, \"Field3\": [\"av1\", \"av2\"] }",
      "Use `walk` to recursively apply a function everywhere.",
      "jq 'walk(if type == \"object\"\n             then\n                 with_entries(.key |= (.[0:1] | ascii_upcase) + (.[1:]))\n             else .\n             end)' file.json"
    ],
    "utterance": "Uppercase the first letter of every property name at all nested levels.",
    "expressions": [
      "walk(if type == \"object\" then with_entries(.key |= (.[0:1] | ascii_upcase) + (.[1:])) else . end)"
    ],
    "data": [
      {
        "input": {
          "field1": "v1",
          "field2": {
            "subfield1": "sv1"
          },
          "field3": [
            "av1",
            "av2"
          ]
        },
        "output": {
          "Field1": "v1",
          "Field2": {
            "Subfield1": "sv1"
          },
          "Field3": [
            "av1",
            "av2"
          ]
        }
      }
    ],
    "identifier": 76599481
  },
  {
    "context": [
      "Now when i want to do further processing on this data,the loop is not returning it as 2 elements,but instead 1.. How do i make it to 1 document at a time within the loop.",
      "In any case, in the following, we first convert your pseuso-JSON to valid JSON, using a bespoke jq function, here named `ObjectId`.",
      "jq -nc \"\n  def ObjectId(s): {ObjectId: s};\n\n  $mongo\n  | .[]\"",
      "Output:\n{\"_id\":{\"ObjectId\":\"64a3f08660a51f2848729093\"},\"setId\":\"64a3f08560a51f2848729092\"}\n{\"_id\":{\"ObjectId\":\"64a3f08660a51f2848729094\"},\"setId\":\"64a3f08560a51f2848729092\"}"
    ],
    "utterance": "Iterate over each document in an array where each '_id' field is an ObjectId, outputting one object at a time for further shell processing.",
    "expressions": [
      "jq -nc '\ndef ObjectId(s): {ObjectId: s};\n$mongo | .[]'"
    ],
    "data": [
      {
        "input": [
          {
            "_id": "ObjectId(\"64a3f08660a51f2848729093\")",
            "setId": "64a3f08560a51f2848729092"
          },
          {
            "_id": "ObjectId(\"64a3f08660a51f2848729094\")",
            "setId": "64a3f08560a51f2848729092"
          }
        ],
        "output": [
          {
            "_id": {
              "ObjectId": "64a3f08660a51f2848729093"
            },
            "setId": "64a3f08560a51f2848729092"
          },
          {
            "_id": {
              "ObjectId": "64a3f08660a51f2848729094"
            },
            "setId": "64a3f08560a51f2848729092"
          }
        ]
      }
    ],
    "identifier": 76612734
  },
  {
    "context": [
      "basically I want to have a function `bool json_is_valid(char* input)` in c. As I use `jq` for the rest of my json stuff, I want to use it for this as well, however I am unable to find a proper way of doing it.",
      "As far as I can tell, `jv_parse` can be used to validate strings of JSON.",
      "Passing the result of this function to `jv_is_valid` appears to get the job done.",
      "A cursory example:",
      "int json_is_valid(const char *json)\n{\n    jv ele = jv_parse(json);\n    int valid = jv_is_valid(ele);\n    jv_free(ele);\n\n    return valid;\n}"
    ],
    "utterance": "Check if a string is well-formed by parsing it and returning true if it is valid according to the parser.",
    "expressions": [
      "jv ele = jv_parse(json); int valid = jv_is_valid(ele); jv_free(ele); return valid;"
    ],
    "data": [
      {
        "input": "{}",
        "output": true
      },
      {
        "input": "[]",
        "output": true
      },
      {
        "input": "[{}]",
        "output": true
      },
      {
        "input": "[][]",
        "output": false
      },
      {
        "input": "\"foo\"",
        "output": true
      },
      {
        "input": "\"foo\":\"bar\"",
        "output": false
      },
      {
        "input": "51",
        "output": true
      },
      {
        "input": "{42: []}",
        "output": false
      },
      {
        "input": "{\"42\":[1, 2, 3]}",
        "output": true
      },
      {
        "input": "'qux'",
        "output": false
      }
    ],
    "identifier": 76613620
  },
  {
    "context": [
      "I especially want to achieve this with one single jq - call for performance-reasons and I'd like to avoid to iterate over it for each regisseur (at least within bash; jq may do iterate, as long as it is fast)",
      "What I'd like to get is a CSV-representation of it looking like this:\nSteven Spielberg;War of the Worlds;\nSteven Spielberg;Jurassic Park;\nGeorge Lucas;Howard The Duck;\nGeorge Lucas;Hook;",
      "jq -r '.[] | .regisseur as $r | .movies[] | [$r, .] | join(\";\")'"
    ],
    "utterance": "Produce a semicolon-separated list of all director and movie pairs, one per line, with each director paired with each of their movies.",
    "expressions": [
      ".[] | .regisseur as $r | .movies[] | [$r, .] | join(\";\")"
    ],
    "data": [
      {
        "input": [
          {
            "regisseur": "Steven Spielberg",
            "movies": [
              "War of the Worlds",
              "Jurassic Park"
            ]
          },
          {
            "regisseur": "George Lucas",
            "movies": [
              "Howard The Duck",
              "Hook"
            ]
          }
        ],
        "output": [
          "Steven Spielberg;War of the Worlds;",
          "Steven Spielberg;Jurassic Park;",
          "George Lucas;Howard The Duck;",
          "George Lucas;Hook;"
        ]
      }
    ],
    "identifier": 76640222
  },
  {
    "context": [
      "Hi I have below code which has individual `key:value` maps needs to be merged into a single `key:value` map",
      "To add each file as element into one big array, you can use [`-s`/`--slurp`](https://jqlang.github.io/jq/manual/#Invokingjq) with the [identity filter `.`](https://jqlang.github.io/jq/manual/#Identity:.):",
      "jq -s '. ' file1.json file2.json",
      "\u2026 or collect [`inputs`](https://jqlang.github.io/jq/manual/#inputs) into [an array](https://jqlang.github.io/jq/manual/#Arrayconstruction:[]) (with `-n`/`--null-input`):",
      "jq -n '[inputs]' file1.json file2.json",
      "or without `-n`:",
      "jq '[., inputs]' file1.json file2.json",
      "Output:",
      "[ { \"Key1\": \"value1\", \"Key2\": \"value2\", \"Key3\": \"value3\", \"Key4\": \"value4\" }, { \"Key1\": \"value1\", \"Key2\": \"value2\", \"Key3\": \"value3\", \"Key4\": \"value4\" } ]"
    ],
    "utterance": "Combine multiple separate key:value objects from different files into one array containing all the objects.",
    "expressions": [
      ".",
      "[inputs]",
      "[., inputs]"
    ],
    "data": [
      {
        "input": [
          {
            "Key1": "value1",
            "Key2": "value2",
            "Key3": "value3",
            "Key4": "value4"
          },
          {
            "Key1": "value1",
            "Key2": "value2",
            "Key3": "value3",
            "Key4": "value4"
          }
        ],
        "output": [
          {
            "Key1": "value1",
            "Key2": "value2",
            "Key3": "value3",
            "Key4": "value4"
          },
          {
            "Key1": "value1",
            "Key2": "value2",
            "Key3": "value3",
            "Key4": "value4"
          }
        ]
      }
    ],
    "identifier": 76614334
  },
  {
    "context": [
      "I have this input JSON array (already slightly preprocessed from turborepo's --dry-run=json output)\n{\n  \"package\": \"@nullvoxpopuli/dev\",\n  \"task\": \"_syncPnpm\",\n  \"local\": false,\n  \"remote\": false,\n  \"status\": \"MISS\",\n  \"timeSaved\": 0\n}\n{\n  \"package\": \"@nullvoxpopuli/dev\",\n  \"task\": \"test\",\n  \"local\": false,\n  \"remote\": false,\n  \"status\": \"MISS\",\n  \"timeSaved\": 0\n}\n{ \n  \"package\": \"another-package\",\n  ...\n  ... etc",
      "I'd like to transform this data in to the following shape:\n{\n  \"@nullvoxpopuli/dev\": {\n    \"_syncPnpm\": {\n      \"local\": false,\n      \"remote\": false,\n      \"status\": \"MISS\",\n      \"timeSaved\": 0\n    },\n    \"test\": {\n      \"local\": false,\n      \"remote\": false,\n      \"status\": \"MISS\",\n      \"timeSaved\": 0  \n    }\n  }\n}",
      "The schem(e|a) for this transform is:\n{\n  [package]: {\n    [task]: {\n      ...the other fields\n    }\n  }\n}",
      "$ jq -n 'reduce (inputs|[.,del(.package,.task)]) as [{$package,$task},$rest] ({};\n  .[$package][$task] |= $rest\n)'",
      "{\n  \"@nullvoxpopuli/dev\": {\n    \"_syncPnpm\": {\n      \"local\": false,\n      \"remote\": false,\n      \"status\": \"MISS\",\n      \"timeSaved\": 0\n    },\n    \"test\": {\n      \"local\": false,\n      \"remote\": false,\n      \"status\": \"MISS\",\n      \"timeSaved\": 0\n    }\n  }\n}"
    ],
    "utterance": "Restructure an array of objects so that each object is nested under its 'package' and 'task' properties, with the remaining fields as the innermost object.",
    "expressions": [
      "reduce (inputs|[.,del(.package,.task)]) as [{$package,$task},$rest] ({}; .[$package][$task] |= $rest)"
    ],
    "data": [
      {
        "input": [
          {
            "package": "@nullvoxpopuli/dev",
            "task": "_syncPnpm",
            "local": false,
            "remote": false,
            "status": "MISS",
            "timeSaved": 0
          },
          {
            "package": "@nullvoxpopuli/dev",
            "task": "test",
            "local": false,
            "remote": false,
            "status": "MISS",
            "timeSaved": 0
          }
        ],
        "output": {
          "@nullvoxpopuli/dev": {
            "_syncPnpm": {
              "local": false,
              "remote": false,
              "status": "MISS",
              "timeSaved": 0
            },
            "test": {
              "local": false,
              "remote": false,
              "status": "MISS",
              "timeSaved": 0
            }
          }
        }
      }
    ],
    "identifier": 76643800
  },
  {
    "context": [
      "The thing is, I want the `storagePolicyName` one level higher, at the same level as `status` item.",
      "What I've tried is this:\n\nneed_this=$(echo \"$data\" | jq '.storagePoolList |= map(.storagePolicyName = .storagePolicyEntity.storagePolicyName | del(.storagePolicyEntity))')",
      "Loop over the `storagePoolList` array, map each object, assign `storagePoolName` to `.storagePoolEntity.storagePoolName`",
      "If you want to remove the `storagePoolEntitiy.storegePoolName` from the inner object, use `del()`:\n(.storagePoolList |= map(.storagePoolName = .storagePoolEntity.storagePoolName | del(.storagePolicyEntity.storagePolicyName)))"
    ],
    "utterance": "Move the storagePolicyName property from within storagePolicyEntity up to the top level of each object in storagePoolList, alongside status.",
    "expressions": [
      ".storagePoolList |= map(.storagePolicyName = .storagePolicyEntity.storagePolicyName)",
      ".storagePoolList |= map(.storagePolicyName = .storagePolicyEntity.storagePolicyName | del(.storagePolicyEntity))"
    ],
    "data": [
      {
        "input": {
          "storagePoolList": [
            {
              "status": "Online",
              "statusCode": 0,
              "storagePolicyEntity": {
                "_type_": 17,
                "storagePolicyName": "n1",
                "storagePolicyId": 38
              },
              "storagePoolEntity": {
                "storagePoolName": "n2",
                "_type_": 160,
                "storagePoolId": 38
              },
              "storagePool": {
                "_type_": 28,
                "clientGroupId": 38,
                "clientGroupName": "ddsa"
              }
            },
            {
              "status": "Online",
              "statusCode": 0,
              "storagePolicyEntity": {
                "_type_": 17,
                "storagePolicyName": "dsa",
                "storagePolicyId": 65
              },
              "storagePoolEntity": {
                "storagePoolName": "dasdas",
                "_type_": 160,
                "storagePoolId": 65
              },
              "storagePool": {
                "_type_": 28,
                "clientGroupId": 65,
                "clientGroupName": "fasdf"
              }
            }
          ]
        },
        "output": {
          "storagePoolList": [
            {
              "status": "Online",
              "statusCode": 0,
              "storagePolicyName": "n1",
              "storagePolicyEntity": {
                "_type_": 17,
                "storagePolicyName": "n1",
                "storagePolicyId": 38
              },
              "storagePoolEntity": {
                "storagePoolName": "n2",
                "_type_": 160,
                "storagePoolId": 38
              },
              "storagePool": {
                "_type_": 28,
                "clientGroupId": 38,
                "clientGroupName": "ddsa"
              }
            },
            {
              "status": "Online",
              "statusCode": 0,
              "storagePolicyName": "dsa",
              "storagePolicyEntity": {
                "_type_": 17,
                "storagePolicyName": "dsa",
                "storagePolicyId": 65
              },
              "storagePoolEntity": {
                "storagePoolName": "dasdas",
                "_type_": 160,
                "storagePoolId": 65
              },
              "storagePool": {
                "_type_": 28,
                "clientGroupId": 65,
                "clientGroupName": "fasdf"
              }
            }
          ]
        }
      },
      {
        "input": {
          "storagePoolList": [
            {
              "status": "Online",
              "statusCode": 0,
              "storagePolicyEntity": {
                "_type_": 17,
                "storagePolicyName": "n1",
                "storagePolicyId": 38
              },
              "storagePoolEntity": {
                "storagePoolName": "n2",
                "_type_": 160,
                "storagePoolId": 38
              },
              "storagePool": {
                "_type_": 28,
                "clientGroupId": 38,
                "clientGroupName": "ddsa"
              }
            },
            {
              "status": "Online",
              "statusCode": 0,
              "storagePolicyEntity": {
                "_type_": 17,
                "storagePolicyName": "dsa",
                "storagePolicyId": 65
              },
              "storagePoolEntity": {
                "storagePoolName": "dasdas",
                "_type_": 160,
                "storagePoolId": 65
              },
              "storagePool": {
                "_type_": 28,
                "clientGroupId": 65,
                "clientGroupName": "fasdf"
              }
            }
          ]
        },
        "output": {
          "storagePoolList": [
            {
              "status": "Online",
              "statusCode": 0,
              "storagePolicyName": "n1",
              "storagePoolEntity": {
                "storagePoolName": "n2",
                "_type_": 160,
                "storagePoolId": 38
              },
              "storagePool": {
                "_type_": 28,
                "clientGroupId": 38,
                "clientGroupName": "ddsa"
              }
            },
            {
              "status": "Online",
              "statusCode": 0,
              "storagePolicyName": "dsa",
              "storagePoolEntity": {
                "storagePoolName": "dasdas",
                "_type_": 160,
                "storagePoolId": 65
              },
              "storagePool": {
                "_type_": 28,
                "clientGroupId": 65,
                "clientGroupName": "fasdf"
              }
            }
          ]
        }
      }
    ],
    "identifier": 76611896
  },
  {
    "context": [
      "I want to parse message field and The desired format like this:",
      "|Time(UTC)|clientIP|user@db|Query_time(ms)|Query|",
      "|---|---|---|---|---|---|---|---|",
      "|2023-07-06 03:55:24|11.11.11.11|testUser@postgres|2004.016|select pg_sleep(2)|",
      "|2023-07-06 03:58:42|111.22.331.41|testService@postgres|2009.526|select pg_sleep(2)|",
      "Here&#39;s one way using regular expressions with [`capture`](https://jqlang.github.io/jq/manual/v1.6/#capture%28val%29%2Ccapture%28regex%3Bflags%29):",
      ".events[].message | capture([\n  \"(?<date>[\\\\d-]+ [\\\\d:]+)\",\n  \"(?<ip>[\\\\d.]+)\",\n  \"(?<user>[^:]+)\",\n  \"\", \"LOG\", \"duration\",\n  \"(?<time>[\\\\d.]+)\",\n  \"(?<query>.*)\"\n] | join(\"[^:]*: *\"))\n| [.date, .ip, .user, .time, .query | @html \"<td>\\(.)</td>\"]\n| \"<tr>\\(add)</tr>\""
    ],
    "utterance": "Extract each log's date, client IP, user@db, duration in ms, and query from the message field, and format them as HTML table rows with each value inside a <td> element.",
    "expressions": [
      ".events[].message | capture([\n  \"(?<date>[\\d-]+ [\\d:]+)\",\n  \"(?<ip>[\\d.]+)\",\n  \"(?<user>[^\":]+)\",\n  \"\", \"LOG\", \"duration\",\n  \"(?<time>[\\d.]+)\",\n  \"(?<query>.*)\"\n] | join(\"[^:]*: *\"))\n| [.date, .ip, .user, .time, .query | @html \"<td>\\(.)</td>\"]\n| \"<tr>\\(add)</tr>\"",
      ".events[].message | capture([\"(?<date>[\\d-]+ [\\d:]+)\", \"(?<ip>[\\d.]+)\", \"(?<user>[^:]+)\", \"\", \"LOG\", \"duration\", \"(?<time>[\\d.]+)\", \"(?<query>.*)\"] | join(\"[^:]*: *\")) | [.date, .ip, .user, .time, .query | @html | \"<td>\\(.)</td>\"] | \"<tr>\\n\\(map(\"  \\(.)\\n\") | add)</tr>\""
    ],
    "data": [
      {
        "input": {
          "nextForwardToken": "f/37657393414703861243420284798371757973629840396172525568/s",
          "events": [
            {
              "ingestionTime": 1688615727267,
              "timestamp": 1688615724000,
              "message": "2023-07-06 03:55:24 UTC:11.11.11.11(51400):testUser@postgres:[9802]:LOG:  duration: 2004.016 ms  statement: select pg_sleep(2);"
            },
            {
              "ingestionTime": 1688615925270,
              "timestamp": 1688615922000,
              "message": "2023-07-06 03:58:42 UTC:111.22.331.41(1230):testService@postgres:[8602]:LOG:  duration: 2009.526 ms  statement: select pg_sleep(2);"
            }
          ],
          "nextBackwardToken": "b/37657388999156311934356902534929058635511305773902397440/s"
        },
        "output": [
          "<tr><td>2023-07-06 03:55:24</td><td>11.11.11.11</td><td>testUser@postgres</td><td>2004.016</td><td>select pg_sleep(2);</td></tr>",
          "<tr><td>2023-07-06 03:58:42</td><td>111.22.331.41</td><td>testService@postgres</td><td>2009.526</td><td>select pg_sleep(2);</td></tr>"
        ]
      }
    ],
    "identifier": 76625723
  },
  {
    "context": [
      "I\u2019m trying to merge these objects (preferably appending arrays from common x values) and not having any luck.",
      "Expected output would be:\n{\n    \"x\": \"t\",\n    \"y\": [\n        [\n            \"a\",\n            \"b\u201d\n        ],\n        [\n            \"c\",\n            \"d\"\n        ]\n    ]\n}\n{\n    \"x\": \"r\",\n    \"y\": [\n        [\n            \"a\",\n            \"c\"\n        ]\n    ]\n}",
      "If you know the actual names of `x` and `y`, you can address them directly (setting `.x` and appending to `.y`) using this `reduce`:\n(reduce data[] as {$x,$y} ({}; .[$x] |= (.x = $x | .y += [$y])))[]",
      "Or use a more functional approach, and `group_by` the common field:\n[data[]] | group_by(.x)[] | {x: .[0].x, y: map(.y)}"
    ],
    "utterance": "Group objects by identical x values and collect each object's y array into an array under y for each group.",
    "expressions": [
      "(reduce data[] as {$x,$y} ({}; .[$x] |= (.x = $x | .y += [$y])))[]",
      "[data[]] | group_by(.x)[] | {x: .[0].x, y: map(.y)}"
    ],
    "data": [
      {
        "input": {
          "a": {
            "x": "t",
            "y": [
              "a",
              "b"
            ]
          },
          "b": {
            "x": "t",
            "y": [
              "c",
              "d"
            ]
          },
          "c": {
            "x": "r",
            "y": [
              "a",
              "c"
            ]
          }
        },
        "output": [
          {
            "x": "t",
            "y": [
              [
                "a",
                "b"
              ],
              [
                "c",
                "d"
              ]
            ]
          },
          {
            "x": "r",
            "y": [
              [
                "a",
                "c"
              ]
            ]
          }
        ]
      }
    ],
    "identifier": 76656017
  },
  {
    "context": [
      "I actually wanted to convert the JSON into XML in following Junit format",
      "Number of alerts becomes the failure and tests count for <testsuite> tag",
      "\"count\": \"3\" becomes failure count for <testcase> tag",
      "Urls are concatenated and shown under  <failure> tag after \"URIs Reported(3):\"",
      "here's (at least for starters) one way how to transform your sample JSON structure into your sample XML using [xq](https://github.com/kislyuk/yq) (which performs JSON <-> XML transformations, and uses jq under the hood):",
      "xq -xn --argfile in input.json '\n  def print: strings /= \"</p><p>\" | map(ltrimstr(\"<p>\") | rtrimstr(\"</p>\")) | join(\" - \");\n  $in | {\n    testsuites: {\n      testsuite: {\n        \"@tests\": (.site | length),\n        \"@failures\": ([.site[].alerts[]] | length),\n        \"@name\": \"\\([.site[].\"@host\"] | print) - \\(.\"@programName\")\",\n        properties: [{\n          property: {\n            \"@name\": \"type\",\n            \"@value\": .\"@programName\"\n          }\n        }],\n        \"testcase\": [.site[] | {\n          \"@classname\": ([.alerts[].name] | print),\n          \"@failures\": ([.alerts[].instances[]] | length),\n          \"@name\": ([.alerts[] | \"[\\((.riskdesc / \" \")[0])] - \\(.name)\"] | print),\n          \"@file\": \"\",\n          failure: [.alerts[] | {\n            \"@message\": .alert,\n            \"@type\": \"failure\",\n            \"#text\": (\n              \"Description: \\(.desc | print) \" +\n              \"URIs Reported(\\(.count)): - \\([.instances[].uri] | print) \" +\n              \"Solution: \\(.solution | print) \" +\n              \"OtherInfo: \\(.otherinfo) \" +\n              \"Reference: - \\(.reference | print)\"\n            )\n          }]\n        }]\n      }\n    }\n  }\n'"
    ],
    "utterance": "Convert security scan results into JUnit XML where the number of alerts sets <testsuite> failure and test counts, each <testcase> uses 'count' for its failure count, and URIs are listed under 'URIs Reported' in the <failure> tag.",
    "expressions": [
      "xq -xn --argfile in input.json '\n  def print: strings /= \"</p><p>\" | map(ltrimstr(\"<p>\") | rtrimstr(\"</p>\")) | join(\" - \");\n  $in | {\n    testsuites: {\n      testsuite: {\n        \"@tests\": (.site | length),\n        \"@failures\": ([.site[].alerts[]] | length),\n        \"@name\": \"\\([.site[].\"@host\"] | print) - \\(.\"@programName\")\",\n        properties: [{\n          property: {\n            \"@name\": \"type\",\n            \"@value\": .\"@programName\"\n          }\n        }],\n        \"testcase\": [.site[] | {\n          \"@classname\": ([.alerts[].name] | print),\n          \"@failures\": ([.alerts[].instances[]] | length),\n          \"@name\": ([.alerts[] | \"[\\((.riskdesc / \" \")[0])] - \\(.name)\"] | print),\n          \"@file\": \"\",\n          failure: [.alerts[] | {\n            \"@message\": .alert,\n            \"@type\": \"failure\",\n            \"#text\": (\n              \"Description: \\(.desc | print) \" +\n              \"URIs Reported(\\(.count)): - \\([.instances[].uri] | print) \" +\n              \"Solution: \\(.solution | print) \" +\n              \"OtherInfo: \\(.otherinfo) \" +\n              \"Reference: - \\(.reference | print)\"\n            )\n          }]\n        }]\n      }\n    }\n  }\n'"
    ],
    "data": [
      {
        "input": {
          "@programName": "OWASP ZAP",
          "@version": "D-2023-05-30",
          "@generated": "Wed, 31 May 2023 16:25:43",
          "site": [
            {
              "@name": "http://127.0.0.1:8000",
              "@host": "127.0.0.1",
              "@port": "8000",
              "@ssl": "false",
              "alerts": [
                {
                  "pluginid": "10038",
                  "alertRef": "10038-1",
                  "alert": "Content Security Policy (CSP) Header Not Set",
                  "name": "Content Security Policy (CSP) Header Not Set",
                  "riskcode": "2",
                  "confidence": "3",
                  "riskdesc": "Medium (High)",
                  "desc": "<p>Content Security Policy (CSP) is an added layer of security that helps to detect and mitigate certain types of attacks, including Cross Site Scripting (XSS) and data injection attacks. These attacks are used for everything from data theft to site defacement or distribution of malware. CSP provides a set of standard HTTP headers that allow website owners to declare approved sources of content that browsers should be allowed to load on that page \u2014 covered types are JavaScript, CSS, HTML frames, fonts, images and embeddable objects such as Java applets, ActiveX, audio and video files.</p>",
                  "instances": [
                    {
                      "uri": "http://127.0.0.1:8000",
                      "method": "GET",
                      "param": "",
                      "attack": "",
                      "evidence": "",
                      "otherinfo": ""
                    },
                    {
                      "uri": "http://127.0.0.1:8000/robots.txt",
                      "method": "GET",
                      "param": "",
                      "attack": "",
                      "evidence": "",
                      "otherinfo": ""
                    },
                    {
                      "uri": "http://127.0.0.1:8000/sitemap.xml",
                      "method": "GET",
                      "param": "",
                      "attack": "",
                      "evidence": "",
                      "otherinfo": ""
                    }
                  ],
                  "count": "3",
                  "solution": "<p>Ensure that your web server, application server, load balancer, etc. is configured to set the Content-Security-Policy header.</p>",
                  "otherinfo": "",
                  "reference": "<p>https://developer.mozilla.org/en-US/docs/Web/Security/CSP/Introducing_Content_Security_Policy</p><p>https://cheatsheetseries.owasp.org/cheatsheets/Content_Security_Policy_Cheat_Sheet.html</p><p>http://www.w3.org/TR/CSP/</p><p>http://w3c.github.io/webappsec/specs/content-security-policy/csp-specification.dev.html</p><p>http://www.html5rocks.com/en/tutorials/security/content-security-policy/</p><p>http://caniuse.com/#feat=contentsecuritypolicy</p><p>http://content-security-policy.com/</p>",
                  "cweid": "693",
                  "wascid": "15",
                  "sourceid": "1"
                }
              ]
            }
          ]
        },
        "output": "<testsuites>\n  <testsuite tests=\"1\" failures=\"1\" name=\"127.0.0.1 - OWASP ZAP\">\n    <properties>\n      <property name=\"type\" value=\"OWASP ZAP\"></property>\n    </properties>\n    <testcase classname=\"Content Security Policy (CSP) Header Not Set\" failures=\"3\" name=\"[Medium] - Content Security Policy (CSP) Header Not Set\" file=\"\">\n      <failure message=\"Content Security Policy (CSP) Header Not Set\" type=\"failure\">Description: Content Security Policy (CSP) is an added layer of security that helps to detect and mitigate certain types of attacks, including Cross Site Scripting (XSS) and data injection attacks. These attacks are used for everything from data theft to site defacement or distribution of malware. CSP provides a set of standard HTTP headers that allow website owners to declare approved sources of content that browsers should be allowed to load on that page \u2014 covered types are JavaScript, CSS, HTML frames, fonts, images and embeddable objects such as Java applets, ActiveX, audio and video files. URIs Reported(3): - http://127.0.0.1:8000 - http://127.0.0.1:8000/robots.txt - http://127.0.0.1:8000/sitemap.xml Solution: Ensure that your web server, application server, load balancer, etc. is configured to set the Content-Security-Policy header. OtherInfo:  Reference: - https://developer.mozilla.org/en-US/docs/Web/Security/CSP/Introducing_Content_Security_Policy - https://cheatsheetseries.owasp.org/cheatsheets/Content_Security_Policy_Cheat_Sheet.html - http://www.w3.org/TR/CSP/ - http://w3c.github.io/webappsec/specs/content-security-policy/csp-specification.dev.html - http://www.html5rocks.com/en/tutorials/security/content-security-policy/ - http://caniuse.com/#feat=contentsecuritypolicy - http://content-security-policy.com/</failure>\n    </testcase>\n  </testsuite>\n</testsuites>\n"
      }
    ],
    "identifier": 76455292
  },
  {
    "context": [
      "I want to iterate over the metrics array and for each entry of the array, I want to look into the json_input and get the value of score from it.",
      "With jq, you could read in the values of the `metrics` array using the `--args` option, then reference them with `$ARGS.positional[]`, and extract the desired values from the input data in `$json_input` using `.[\u2026].score` and the `-r` flag:",
      "jq -r '.[$ARGS.positional[]].score' --args \"${metrics[@]}\" <<< \"$json_input\""
    ],
    "utterance": "For each name in an array, output the corresponding score value from an object where keys match the array values.",
    "expressions": [
      ".[$ARGS.positional[]].score",
      "jq -r '.[$ARGS.positional[]].score' --args \"${metrics[@]}\" <<< \"$json_input\""
    ],
    "data": [
      {
        "input": {
          "performance": {
            "title": "Performance",
            "score": 0.95
          },
          "accessibility": {
            "title": "Accessibility",
            "score": 1
          },
          "bestPractices": {
            "title": "Best Practices",
            "score": 0.92
          },
          "seo": {
            "title": "SEO",
            "score": 0.83
          },
          "progressiveWebApp": {
            "title": "PWA",
            "score": 0.33
          }
        }
      }
    ],
    "identifier": 76669053
  },
  {
    "identifier": 76686882
  },
  {
    "context": [
      "I have some very large (20-100GB) JSON files that I need to split into smaller files.",
      "I found the link below for doing so on Linux, but I am working on Windows. I have jq and it works, but I am not fluent enough to be able to write the requisite code.",
      "The easiest way to deal with the Windows quote issues is to put the jq filter code into a file and call it with -f. When you do this you can use the same code that works on Linux."
    ],
    "utterance": "Split a very large JSON file into smaller files, using a method compatible with Windows.",
    "expressions": [
      "split -l 1000000 yourfile.json splitfile_",
      "jq '.[]' largefile.json | split -l 1 - part_",
      "jq -c '.[]' largefile.json | split -l 1 - part_"
    ],
    "identifier": 76673859
  },
  {
    "context": [
      "I want output to be\n\n    [outer1.outer2.outer3]\n    key1 = value1\n    key2 = value2\n\n    [outer1.outer2.outer4]\n    key1 = value1\n    key2 = value2",
      "Next, format this JSON according to your needs. For example using `to_entries` for both levels:\n```sh\njq --stream -nr '\n  reduce (inputs | select(has(1))) as [$path, $val] ({};\n    .[$path[:-1] | join(\".\")][$path[-1]] = $val\n  )\n  | to_entries[] | \"[\\(.key)]\", (\n      .value | to_entries[] | \"\\(.key) = \\(.value)\"\n    ), \"\"\n'\n```",
      "Alternatively, combine both steps into a single `foreach` iteration with a sliding context window as state:\n```sh\njq --stream -nr '\n  foreach (inputs | select(has(1))) as [$path, $val] ([];\n    [last, ($path[:-1] | join(\".\"))];\n    (select(first != last) | \"\\n[\\(last)]\"), \"\\($path[-1]) = \\($val)\"\n  )                                                              \n'\n```",
      "My take is this:\n\n    . as $data\n    | [ path(.. | scalars) ]\n    | map( . as $p | { prefix: $p[0:-1]|join(\".\"), key: $p[-1], value: $data | getpath($p) })\n    | group_by(.prefix)[]\n    | \"[\\(first.prefix)]\", (.[] | \"\\(.key)=\\(.value)\")\n"
    ],
    "utterance": "List all deeply nested key-value pairs grouped by their path, using section headers in the format [outer1.outer2...], followed by key = value entries for each group.",
    "expressions": [
      "jq --stream -nr '\n  reduce (inputs | select(has(1))) as [$path, $val] ({};\n    .[$path[:-1] | join(\".\")][$path[-1]] = $val\n  )\n  | to_entries[] | \"[\\(.key)]\", (\n      .value | to_entries[] | \"\\(.key) = \\(.value)\"\n    ), \"\"\n'",
      "jq --stream -nr '\n  foreach (inputs | select(has(1))) as [$path, $val] ([];\n    [last, ($path[:-1] | join(\".\"))];\n    (select(first != last) | \"\\n[\\(last)]\"), \"\\($path[-1]) = \\($val)\"\n  )\n'",
      ". as $data\n| [ path(.. | scalars) ]\n| map( . as $p | { prefix: $p[0:-1]|join(\".\"), key: $p[-1], value: $data | getpath($p) })\n| group_by(.prefix)[]\n| \"[\\(first.prefix)]\", (.[] | \"\\(.key)=\\(.value)\")"
    ],
    "data": [
      {
        "input": {
          "outer1": {
            "outer2": {
              "outer3": {
                "key1": "value1",
                "key2": "value2"
              },
              "outer4": {
                "key1": "value1",
                "key2": "value2"
              }
            }
          }
        },
        "output": "[outer1.outer2.outer3]\nkey1 = value1\nkey2 = value2\n\n[outer1.outer2.outer4]\nkey1 = value1\nkey2 = value2\n"
      }
    ],
    "identifier": 76665077
  },
  {
    "context": [
      "I have a file containing a sequence of json objects. Using the jq tool, how can I get the first json object from that file?",
      "you could\n\n- slurp the entire input and then print the first array element:\n\n  $ jq -s '.[0]' in.json \n  {\n    \"a\": \"b\"\n  }\n",
      "- use null-input, and then `inputs`:\n\n  $ jq -n '[inputs][0]' in.json \n  {\n    \"a\": \"b\"\n  }\n",
      "Null input (`-n`) is useful in such a case:\n\njq -n 'input' file.json\n\nThe [`input` filter](https://jqlang.github.io/jq/manual/#input) will read a single JSON element from the provided input stream."
    ],
    "utterance": "Select the first object from a file containing a sequence of objects, each on its own line.",
    "expressions": [
      "jq -s '.[0]' input.jsonl",
      "jq -n '[inputs][0]' input.jsonl",
      "jq -n 'input' input.jsonl"
    ],
    "data": [
      {
        "input": "{ \"a\": \"b\" }\n{ \"c\": \"d\" }",
        "output": {
          "a": "b"
        }
      }
    ],
    "identifier": 76680728
  },
  {
    "context": [
      "I'm trying to query some JSON that requires unpacking key-value pairs into top-level fields in the output. However it's common for key-values to only appear in some rows in the input, in which case I want to fallback to null.",
      "And expected output:\n\n{\n  \"id\": \"123\",\n  \"label1\": null,\n  \"label2\": null,\n  \"label3\": \"abc\",\n  \"label4\": \"def\"\n}\n{\n  \"id\": \"345\",\n  \"label1\": \"foo\",\n  \"label2\": \"bar\",\n  \"label3\": null,\n  \"label4\": null\n}\n{\n  \"id\": \"789\",\n  \"label1\": null,\n  \"label2\": null,\n  \"label3\": null,\n  \"label4\": null\n}",
      "Would the following work for you?\n\n{\n  id }\n+ (\n    [.details[] | select(.headerText == \"only_look_at_kvs_here\") | .rows[] | {key, value:.val}]\n    | from_entries\n    | {\n        label1,\n        label2,\n        label3,\n        label4\n    }\n)",
      "Then, how about statically predefining your preferred set of labels (either statically as part of the code, or on call using the `--args` option), which is then used to accordingly generate the \"base object\", and to ignore all other keys from the input in a second filter.",
      "jq '\n  [\"label1\", \"label2\", \"label3\", \"label4\"] as $labels | reduce (\n    .details[] | select(.headerText == \"only_look_at_kvs_here\")\n    | .rows[] | select(IN(.key; $labels[]))\n  ) as {$key, $val} ({id} | .[$labels[]] = null; .[$key] = $val)\n' input.json",
      "reduce (.details[] | select(.headerText == \"only_look_at_kvs_here\"))\nas $details (\n    {id, label1:null, label2:null, label3:null, label4:null};\n    . + ($details.rows | map({key, value:.val}) | from_entries)\n)"
    ],
    "utterance": "Extract id and specified label fields from the nested key-value pairs in the object with headerText 'only_look_at_kvs_here', setting missing labels to null.",
    "expressions": [
      "{ id } + ([.details[] | select(.headerText == \"only_look_at_kvs_here\") | .rows[] | {key, value:.val}] | from_entries | {label1,label2,label3,label4})",
      "[\"label1\", \"label2\", \"label3\", \"label4\"] as $labels | reduce (.details[] | select(.headerText == \"only_look_at_kvs_here\") | .rows[] | select(IN(.key; $labels[]))) as {$key, $val} ({id} | .[$labels[]] = null; .[$key] = $val)",
      "reduce (.details[] | select(.headerText == \"only_look_at_kvs_here\")) as $details ({id, label1:null, label2:null, label3:null, label4:null}; . + ($details.rows | map({key, value:.val}) | from_entries))"
    ],
    "data": [
      {
        "input": {
          "id": "123",
          "details": [
            {
              "headerText": "ignore_me",
              "rows": [
                {
                  "key": "label1",
                  "val": "sdhf"
                },
                {
                  "key": "label2",
                  "val": "fdgg"
                }
              ]
            },
            {
              "headerText": "only_look_at_kvs_here",
              "rows": [
                {
                  "key": "label3",
                  "val": "abc"
                },
                {
                  "key": "label4",
                  "val": "def"
                },
                {
                  "key": "label5",
                  "val": "qwe"
                }
              ]
            }
          ]
        },
        "output": {
          "id": "123",
          "label1": null,
          "label2": null,
          "label3": "abc",
          "label4": "def"
        }
      },
      {
        "input": {
          "id": "345",
          "details": [
            {
              "headerText": "ignore_me",
              "rows": [
                {
                  "key": "label1",
                  "val": "abc"
                },
                {
                  "key": "label2",
                  "val": "def"
                }
              ]
            },
            {
              "headerText": "only_look_at_kvs_here",
              "rows": [
                {
                  "key": "label1",
                  "val": "foo"
                },
                {
                  "key": "label2",
                  "val": "bar"
                }
              ]
            }
          ]
        },
        "output": {
          "id": "345",
          "label1": "foo",
          "label2": "bar",
          "label3": null,
          "label4": null
        }
      },
      {
        "input": {
          "id": "789",
          "details": [
            {
              "headerText": "ignore_me",
              "rows": [
                {
                  "key": "label1",
                  "val": "abc"
                },
                {
                  "key": "label2",
                  "val": "def"
                }
              ]
            }
          ]
        },
        "output": {
          "id": "789",
          "label1": null,
          "label2": null,
          "label3": null,
          "label4": null
        }
      }
    ],
    "identifier": 76539139
  },
  {
    "context": [
      "I want to add a validation for two conditions:",
      "- val is either an object  or",
      "- val.data is null",
      "I want to print a message \"data not parsed correctly\"",
      "I want to print a message \"data is null\"",
      "With [tag:jq]",
      "if val=$(curl ... \\",
      "         | jq 'try ",
      "                 if .data != null ",
      "                   then . ",
      "                   else (\"is null\" | halt_error) ",
      "                 end ",
      "               catch",
      "                 (\"not an object\" | halt_error)",
      "            ' 2>&1",
      "        )"
    ],
    "utterance": "Validate that input is an object and its data field is not null, otherwise signal an error with a custom message.",
    "expressions": [
      "try if .data != null then . else (\"is null\" | halt_error) end catch (\"not an object\" | halt_error)"
    ],
    "data": [
      {
        "input": {
          "parm1": "****",
          "data": "adfsdfsdaf"
        },
        "output": {
          "parm1": "****",
          "data": "adfsdfsdaf"
        }
      },
      {
        "input": {
          "parm1": "****",
          "data": null
        },
        "output": "is null"
      },
      {
        "input": null,
        "output": "not an object"
      }
    ],
    "identifier": 76683161
  },
  {
    "context": [
      "And my jq command, i want to get all the value, with and without array elements. I didn&#39;t get nothing when i get the value data.media.postPaymentEvent[0].transactionDate.",
      "The easiest way to amend your code to work is to change `[0]` to `.0`, and then match integers and cast them to numbers.",
      "[\r\n  \"creation_date\",\r\n  \"data.transactionType\",\r\n  \"data.location.zoneId\",\r\n  \"data.media.typeCode\",\r\n  \"data.media.postPaymentEvent.0.transactionDate\",\r\n  \"id\"\r\n] as $h |\r\n\r\n$h,\r\n(inputs | ([getpath($h[] |\r\n                    . / \".\" |\r\n                    map(if test(\"^[[:digit:]]+$\")\r\n                        then tonumber\r\n                        else . end))\r\n           ])) | @csv"
    ],
    "utterance": "Extract values from both top-level and nested array elements including data.media.postPaymentEvent.0.transactionDate, and output them as CSV columns.",
    "expressions": [
      "[\n  \"creation_date\",\n  \"data.transactionType\",\n  \"data.location.zoneId\",\n  \"data.media.typeCode\",\n  \"data.media.postPaymentEvent.0.transactionDate\",\n  \"id\"\n] as $h |\n\n$h,\n(inputs | ([getpath($h[] |\n                    . / \".\" |\n                    map(if test(\"^[[:digit:]]+$\")\n                        then tonumber\n                        else . end))\n           ])) | @csv"
    ],
    "data": [
      {
        "input": {
          "creation_date": "2023/06/16 15:55:09",
          "data": {
            "transactionType": "val",
            "environment": "1",
            "location": {
              "zoneId": 2
            },
            "media": {
              "typeCode": 15,
              "postPaymentEvent": [
                {
                  "transactionDate": "2022-12-26T16:50:00+01:00",
                  "vehicleType": 1,
                  "vehicleId": 1533
                },
                {
                  "transactionDate": "2022-12-27T16:31:00+01:00",
                  "vehicleType": 1,
                  "vehicleId": 1533
                },
                {
                  "transactionDate": "2022-12-28T15:50:00+01:00",
                  "vehicleType": 1,
                  "vehicleId": 1533
                }
              ]
            },
            "deviceConfiguration": [
              {
                "id": "PLATFORM_PAR",
                "version": "2.6"
              },
              {
                "id": "PLATFORM_SOFT",
                "version": "2.6"
              }
            ]
          },
          "id": "000-0"
        },
        "output": "\"creation_date\",\"data.transactionType\",\"data.location.zoneId\",\"data.media.typeCode\",\"data.media.postPaymentEvent.0.transactionDate\",\"id\"\n\"2023/06/16 15:55:09\",\"val\",2,15,\"2022-12-26T16:50:00+01:00\",\"000-0\""
      }
    ],
    "identifier": 76696095
  },
  {
    "context": [
      "I want to preserve the overall structure and pick off selected elements from the top level as well as the two nested levels in the arrays. This is my desired result.",
      "How do I apply the with_entries filter to the initial down select of the top level?",
      "Now, you could further factor out `.resources[]` from the loops to prevent double iteration, and, apparently, therein you also want to filter for `{resource, checks}` (to remove `.installed`):",
      "use a constructive approach, and directly set everything you want to be contained (with using `map` on arrays):",
      "Or more directly, construct your result picking out the properties at the start."
    ],
    "utterance": "Select only the image, os, resources, and check_summary fields at the top level, and for each item in resources, keep only the resource object (with name and version) and its checks array (with name and description for each check).",
    "expressions": [
      "{image, os, resources, check_summary} | .resources[] |= ({resource, checks} | .resource |= {name, version} | .checks[] |= {name, description})",
      "{image, os, resources: .resources | map({resource: .resource | {name, version}, checks: .checks | map({name, description})}), check_summary}"
    ],
    "data": [
      {
        "input": {
          "image": "test",
          "duration": 40,
          "image_size": 2758644359,
          "os": "rhel",
          "version": "9.2",
          "resources": [
            {
              "resource": {
                "format": "rpm",
                "name": "binutils",
                "version": "2.35.2-37.el9",
                "src_version": "2.35.2-37.el9"
              },
              "installed": true,
              "checks": [
                {
                  "name": "check1",
                  "description": "first check",
                  "severity": "moderate",
                  "depth": 5.5
                },
                {
                  "description": "second check",
                  "severity": "moderate",
                  "depth": 4.7
                },
                {
                  "name": "check3",
                  "description": "third check",
                  "severity": "low",
                  "depth": 4.2
                }
              ]
            },
            {
              "resource": {
                "format": "rpm",
                "name": "dbus",
                "version": "1:1.12.20-7.el9_1",
                "src_version": "1:1.12.20-7.el9_1"
              },
              "installed": true,
              "checks": [
                {
                  "description": "second check",
                  "severity": "moderate",
                  "depth": 6.2
                }
              ]
            },
            {
              "resource": {
                "format": "rpm",
                "name": "dmidecode",
                "version": "1:3.3-7.el9",
                "src_version": "1:3.3-7.el9"
              },
              "installed": true,
              "checks": [
                {
                  "name": "check1",
                  "description": "first check",
                  "severity": "moderate",
                  "depth": 5.5
                },
                {
                  "description": "second check",
                  "severity": "moderate",
                  "depth": 7.1
                }
              ]
            },
            {
              "resource": {
                "format": "rpm",
                "name": "gcc",
                "version": "11.3.1-4.3.el9",
                "src_version": "11.3.1-4.3.el9"
              },
              "installed": true,
              "checks": []
            }
          ],
          "image_assurance_results": {},
          "check_summary": {
            "total": 6,
            "low": 1,
            "moderate": 5
          },
          "initiating_user": "test_user"
        },
        "output": {
          "image": "test",
          "os": "rhel",
          "resources": [
            {
              "resource": {
                "name": "binutils",
                "version": "2.35.2-37.el9"
              },
              "checks": [
                {
                  "name": "check1",
                  "description": "first check"
                },
                {
                  "description": "second check"
                },
                {
                  "name": "check3",
                  "description": "third check"
                }
              ]
            },
            {
              "resource": {
                "name": "dbus",
                "version": "1:1.12.20-7.el9_1"
              },
              "checks": [
                {
                  "description": "second check"
                }
              ]
            },
            {
              "resource": {
                "name": "dmidecode",
                "version": "1:3.3-7.el9"
              },
              "checks": [
                {
                  "name": "check1",
                  "description": "first check"
                },
                {
                  "description": "second check"
                }
              ]
            },
            {
              "resource": {
                "name": "gcc",
                "version": "11.3.1-4.3.el9"
              },
              "checks": []
            }
          ],
          "check_summary": {
            "total": 6,
            "low": 1,
            "moderate": 5
          }
        }
      }
    ],
    "identifier": 76673014
  }
]