[
  {
    "context": [
      "How to parse and convert string list to JSON string array in shell command?",
      "'[\"test1\",\"test2\",\"test3\"]'\nto \n\ntest1\n    test2\n    test3",
      "eval \"array=($( jq -r 'map( @sh ) | join(\" \")' <<<\"$json\" ))\"",
      "mapfile -d '' array < <(jq -j '.[] + \"\\u0000\"' <<< \"$string\")"
    ],
    "utterance": "Extract each element from a string representation of an array and output each value on its own line.",
    "expressions": [
      ".[]",
      "-r '.[]'",
      "-j '.[] + \"\\u0000\"'"
    ],
    "data": [
      {
        "input": "[\"test1\",\"test2\",\"test3\"]",
        "output": [
          "test1",
          "test2",
          "test3"
        ]
      }
    ],
    "identifier": 71053907
  },
  {
    "context": [
      "I need to replace slash character by \"-\".",
      "I mean:",
      "[\n  \"1934/08/20\",\n  \"1961/01/10\",\n  \"1952/01/25\",\n  \"1967/07/24\"\n]",
      "I need:",
      "[\n  \"1934-08-20\",\n  \"1961-01-10\",\n  \"1952-01-25\",\n  \"1967-07-24\"\n]",
      "Since you want to replace all the `/` with `-`'s, [`gsub`][1] is the way to go:",
      "jq 'map(gsub(\"/\"; \"-\"))'"
    ],
    "utterance": "Replace all slashes with dashes in each string of a list of dates.",
    "expressions": [
      "map(gsub(\"/\"; \"-\"))"
    ],
    "data": [
      {
        "input": [
          "1934/08/20",
          "1961/01/10",
          "1952/01/25",
          "1967/07/24"
        ],
        "output": [
          "1934-08-20",
          "1961-01-10",
          "1952-01-25",
          "1967-07-24"
        ]
      }
    ],
    "identifier": 71036664
  },
  {
    "context": [
      "Is there any way to output as \"slurp\" format and input array?",
      "I'd like to get:\n\n{\n \"id\": \"id1\", \"value\": \"value1\"}\n{\n \"id\": \"id2\", \"value\": \"value2\"}\n\nEach element outside of array, and each element into a single line.",
      "I've tried with `-c` option. but it generating all array into a single line.",
      "`jq -c '.[]'` does what you want:"
    ],
    "utterance": "Output each element of an input array on its own line in compact form, with each element separated and not wrapped in an array.",
    "expressions": [
      ".[]",
      "-c .[]"
    ],
    "data": [
      {
        "input": [
          {
            "id": "id1",
            "value": "value1"
          },
          {
            "id": "id2",
            "value": "value2"
          }
        ],
        "output": [
          {
            "id": "id1",
            "value": "value1"
          },
          {
            "id": "id2",
            "value": "value2"
          }
        ]
      }
    ],
    "identifier": 71032520
  },
  {
    "context": [
      "what i want to do is to add items in queue[] of user admin like this",
      "jq '.users[] | select(.username == \"admin\").queue += [\"dev\"]'",
      "With the pipe you are changing the context down to an array element, which is what you want for the selection. If you put parentheses around the pipe and the selection, you will keep the assignment and thus the filter's output on top-level:",
      "jq '(.users[] | select(.username == \"admin\")).queue += [\"dev\"]'",
      "{\n  \"users\": [\n    {\n      \"username\": \"karim\",\n      \"queue\": [\n        \"default\"\n      ]\n    },\n    {\n      \"username\": \"admin\",\n      \"queue\": [\n        \"apps\",\n        \"prod\",\n        \"dev\"\n      ]\n    }\n  ]\n}"
    ],
    "utterance": "Add the value \"dev\" to the queue array of the user whose username is \"admin\", and preserve the full users array structure in the output.",
    "expressions": [
      "(.users[] | select(.username == \"admin\")).queue += [\"dev\"]"
    ],
    "data": [
      {
        "input": {
          "users": [
            {
              "username": "karim",
              "queue": [
                "default"
              ]
            },
            {
              "username": "admin",
              "queue": [
                "apps",
                "prod"
              ]
            }
          ]
        },
        "output": {
          "users": [
            {
              "username": "karim",
              "queue": [
                "default"
              ]
            },
            {
              "username": "admin",
              "queue": [
                "apps",
                "prod",
                "dev"
              ]
            }
          ]
        }
      }
    ],
    "identifier": 71039547
  },
  {
    "context": [
      "I want to delete all the \"comment\"s.",
      "So my output would be ... [example output with all \"comment\" keys removed]",
      "del( .. | objects | .comment )"
    ],
    "utterance": "Remove all keys named \"comment\" from the data structure, regardless of their location.",
    "expressions": [
      "del( .. | objects | .comment )"
    ],
    "data": [
      {
        "input": {
          "Id": 9999,
          "Match": "fqdn=server.fqdn.com",
          "Value": {
            "user1": {
              "order": 90,
              "nofile": {
                "comment": "I want to lose this comment",
                "soft": "65535",
                "hard": "65535"
              },
              "nproc": {
                "comment": "I want to lose this also",
                "soft": "32768",
                "hard": "32768"
              }
            },
            "user2": {
              "order": 90,
              "nofile": {
                "comment": "I want to lose this comment",
                "soft": "65535",
                "hard": "65535"
              },
              "nproc": {
                "comment": "I want to lose this also",
                "soft": "32768",
                "hard": "32768"
              }
            }
          }
        },
        "output": {
          "Id": 9999,
          "Match": "fqdn=server.fqdn.com",
          "Value": {
            "user1": {
              "order": 90,
              "nofile": {
                "soft": "65535",
                "hard": "65535"
              },
              "nproc": {
                "soft": "32768",
                "hard": "32768"
              }
            },
            "user2": {
              "order": 90,
              "nofile": {
                "soft": "65535",
                "hard": "65535"
              },
              "nproc": {
                "soft": "32768",
                "hard": "32768"
              }
            }
          }
        }
      }
    ],
    "identifier": 71052248
  },
  {
    "context": [
      "What I want to do is to take the values of every apps.name and result and pass that to curl:\n```\ncurl -XPOST http://localhost --data-raw 'app=$appsName result=$result'\n```",
      "jq -r '&quot;\\( .apps.name ) \\( .result )&quot;' |",
      "jq -r '&quot;app=\\( .apps.name ) result=\\( .result )&quot;' |",
      "jq < data.json '[.apps.name, .result]|@tsv' -r"
    ],
    "utterance": "Extract each object's apps.name and result values, formatting them as 'app=<apps.name> result=<result>' on separate lines.",
    "expressions": [
      ". as $o | \"app=\u001b[.apps.name] result=\u001b[.result]\"",
      "\"app=\\(.apps.name) result=\\(.result)\"",
      "[.apps.name, .result] | @tsv"
    ],
    "data": [
      {
        "input": {
          "apps": {
            "code": "200",
            "name": "app1"
          },
          "result": "1"
        },
        "output": "app=app1 result=1"
      },
      {
        "input": {
          "apps": {
            "code": "200",
            "name": "app2"
          },
          "result": "5"
        },
        "output": "app=app2 result=5"
      }
    ],
    "identifier": 71039966
  },
  {
    "identifier": 71070808
  },
  {
    "context": [
      "I need to convert seconds to date:",
      "My input documents are:",
      "{...\"birthDate\":{\"value\":{\"$date\":{\"$numberLong\":\"-469929600000\"}}}}",
      "I need to get:",
      "{\"_id\":\"ae53d3ec-8fc3-44fc-a7eb-f2f32da4eaae\",\"birthDate\":\"1955-02-10\"}",
      "Grab the source value, chop off the last three digits to turn the number into seconds and call `todate` to convert it into a date string (GMT).",
      "jq -c '.birthDate |= (.value.\"$date\".\"$numberLong\"[:-3] | tonumber | todate[:10])'",
      ".birthDate |= (\n   .value.\"$date\".\"$numberLong\" |\n   tonumber |\n   . / 1000 |\n   strftime(\"%F\")\n)"
    ],
    "utterance": "Transform the nested birthDate millisecond timestamp into an ISO date string in the format YYYY-MM-DD, preserving the _id.",
    "expressions": [
      ".birthDate |= (.value.\"$date\".\"$numberLong\"[:-3] | tonumber | todate[:10])",
      ".birthDate |= (.value.\"$date\".\"$numberLong\" | tonumber | . / 1000 | strftime(\"%F\"))"
    ],
    "data": [
      {
        "input": {
          "_id": "ae53d3ec-8fc3-44fc-a7eb-f2f32da4eaae",
          "birthDate": {
            "value": {
              "$date": {
                "$numberLong": "-469929600000"
              }
            }
          }
        },
        "output": {
          "_id": "ae53d3ec-8fc3-44fc-a7eb-f2f32da4eaae",
          "birthDate": "1955-02-10"
        }
      },
      {
        "input": {
          "_id": "ef92c3e4-d5d7-4b81-8a0b-1ab1eac10331",
          "birthDate": {
            "value": {
              "$date": {
                "$numberLong": "-854755200000"
              }
            }
          }
        },
        "output": {
          "_id": "ef92c3e4-d5d7-4b81-8a0b-1ab1eac10331",
          "birthDate": "1942-12-01"
        }
      }
    ],
    "identifier": 71040411
  },
  {
    "context": [
      "Given this data, which is two distinct objects, one having an array of keys and the other a dictionary of key value pairs:",
      "I am trying to produce this, the first object with the keys replaced with the values from the dictionary.  NOTE:  I would be fine with renaming services[] to URLs[] if it makes things easier.",
      "Create an `INDEX` to lookup in, then `map` each element you want to change according to the index.",
      "jq ' INDEX(.release.services[]; .service) as $index | {servers} | .servers[].services[] |= $index[.].URL '"
    ],
    "utterance": "Replace the service names in each server's services array with their corresponding URLs as defined in the release services list.",
    "expressions": [
      "INDEX(.release.services[]; .service) as $index | {servers} | .servers[].services[] |= $index[.].URL"
    ],
    "data": [
      {
        "input": {
          "servers": [
            {
              "location": "server4",
              "services": [
                "srv07",
                "srv06",
                "srv01",
                "srv04"
              ]
            },
            {
              "location": "server2",
              "services": [
                "srv07",
                "srv02",
                "srv05",
                "srv03"
              ]
            }
          ],
          "release": {
            "id": "release1",
            "services": [
              {
                "service": "srv01",
                "URL": "/srv01_service/v1.20.0"
              },
              {
                "service": "srv02",
                "URL": "/srv02_service/v1.14.0"
              },
              {
                "service": "srv03",
                "URL": "/srv03_service/v1.15.0"
              },
              {
                "service": "srv04",
                "URL": "/srv04_service/v1.18.0"
              },
              {
                "service": "srv05",
                "URL": "/srv05_service/v1.14.0"
              },
              {
                "service": "srv06",
                "URL": "/srv06_serv/v1.13.0"
              },
              {
                "service": "srv07",
                "URL": "/srv07_service/v1.19.0"
              }
            ]
          }
        },
        "output": {
          "servers": [
            {
              "location": "server4",
              "services": [
                "/srv07_service/v1.19.0",
                "/srv06_serv/v1.13.0",
                "/srv01_service/v1.20.0",
                "/srv04_service/v1.18.0"
              ]
            },
            {
              "location": "server2",
              "services": [
                "/srv07_service/v1.19.0",
                "/srv02_service/v1.14.0",
                "/srv05_service/v1.14.0",
                "/srv03_service/v1.15.0"
              ]
            }
          ]
        }
      }
    ],
    "identifier": 71040128
  },
  {
    "context": [
      "how to do I update the time value in the object. I can get the conversion to work but can\u2019t seem to update the value with the output.",
      "To modify, use an assignment: (you were almost there)\n\n```\n.[].time |= (sub(\"\\\\.\\\\d+Z$\"; \"Z\") | fromdate)\n```",
      "To recreate, map it.\n\n```\nmap(.time |= (sub(\"\\\\.\\\\d+Z$\"; \"Z\") | fromdate))\n```"
    ],
    "utterance": "Replace the value of 'time' in each object in the array with its Unix timestamp, removing fractional seconds.",
    "expressions": [
      ".[].time |= (sub(\"\\\\.\\\\d+Z$\"; \"Z\") | fromdate)",
      "map(.time |= (sub(\"\\\\.\\\\d+Z$\"; \"Z\") | fromdate))"
    ],
    "data": [
      {
        "input": [
          {
            "time": "2022-01-28T17:50:31.620Z"
          }
        ],
        "output": [
          {
            "time": 1643392231
          }
        ]
      }
    ],
    "identifier": 71058266
  },
  {
    "context": [
      "I\u2019d like to add a `proxy-url` field to the currently active `clusters` entry of my kubeconfig file. The \"active\" cluster is identified by the \"active\" context, which is itself identified by a top-level key `current-context`.",
      "This solution retrieves the active cluster using an `INDEX` construction, then just sets the new field directly without modifying the context:",
      "jq '\n  INDEX(.contexts[]; .name)[.\"current-context\"].context.cluster as $cluster\n  | (.clusters[] | select(.name == $cluster)).\"proxy-url\" = \"my-url\"\n'"
    ],
    "utterance": "Add a field named proxy-url with value my-url to the cluster in clusters whose name matches the cluster referenced by the context named by current-context.",
    "expressions": [
      "INDEX(.contexts[]; .name)[.\"current-context\"].context.cluster as $cluster | (.clusters[] | select(.name == $cluster)).\"proxy-url\" = \"my-url\""
    ],
    "data": [
      {
        "input": {
          "clusters": [
            {
              "name": "cluster1",
              "field": "field1"
            },
            {
              "name": "cluster2",
              "field": "field2"
            }
          ],
          "contexts": [
            {
              "name": "context1",
              "context": {
                "cluster": "cluster1"
              }
            },
            {
              "name": "context2",
              "context": {
                "cluster": "cluster2"
              }
            }
          ],
          "current-context": "context1"
        },
        "output": {
          "clusters": [
            {
              "name": "cluster1",
              "field": "field1",
              "proxy-url": "my-url"
            },
            {
              "name": "cluster2",
              "field": "field2"
            }
          ],
          "contexts": [
            {
              "name": "context1",
              "context": {
                "cluster": "cluster1"
              }
            },
            {
              "name": "context2",
              "context": {
                "cluster": "cluster2"
              }
            }
          ],
          "current-context": "context1"
        }
      }
    ],
    "identifier": 71058051
  },
  {
    "context": [
      "The goal is to sort the bill rates array by the percentage while maintaining the original json object.",
      "Use the update operator `|=` to preserve the overall structure, and a negative comparison value `-.percentage` to sort in descending order:",
      "jq '.[].employee_observations[].bill_rates |= sort_by(-.percentage)'"
    ],
    "utterance": "Sort each bill_rates array inside employee_observations objects by percentage in descending order, keeping the rest of the data structure unchanged.",
    "expressions": [
      ".[].employee_observations[].bill_rates |= sort_by(-.percentage)"
    ],
    "data": [
      {
        "input": [
          {
            "id": 2,
            "employee_observations": [
              {
                "id": 1,
                "bill_rates": [
                  {
                    "bill_classification": "Lawn Mowing",
                    "percentage": 0.672399672399672
                  },
                  {
                    "bill_classification": "Trimming",
                    "percentage": 0.00163800163800164
                  },
                  {
                    "bill_classification": "Snow Removal",
                    "percentage": 0.630630630630631
                  },
                  {
                    "bill_classification": "Rock Removal",
                    "percentage": 0.00163800163800164
                  }
                ]
              }
            ]
          }
        ],
        "output": [
          {
            "id": 2,
            "employee_observations": [
              {
                "id": 1,
                "bill_rates": [
                  {
                    "bill_classification": "Lawn Mowing",
                    "percentage": 0.672399672399672
                  },
                  {
                    "bill_classification": "Snow Removal",
                    "percentage": 0.630630630630631
                  },
                  {
                    "bill_classification": "Rock Removal",
                    "percentage": 0.00163800163800164
                  },
                  {
                    "bill_classification": "Trimming",
                    "percentage": 0.00163800163800164
                  }
                ]
              }
            ]
          }
        ]
      }
    ],
    "identifier": 71074096
  },
  {
    "context": [
      "I want to use `jq` to format a JSON file in Windows.",
      "Is there a way to instruct `jq` to do this without performing these gymnastics?",
      "`jq` has no option to do this for you.",
      "jq . \"%1\" >\"%1\".tmp",
      "if not errorlevel 1 move /y \"%1\".tmp \"%1\" >nul"
    ],
    "utterance": "Format a file and overwrite the original with the formatted output in Windows.",
    "expressions": [
      "jq . \"%1\" >\"%1\".tmp",
      "if not errorlevel 1 move /y \"%1\".tmp \"%1\" >nul"
    ],
    "identifier": 71085709
  },
  {
    "context": [
      "Goal is to search for null values of part_description and insert in part field value.",
      "jq '(.[] | select(.part_description==null).part_description) |= .part'",
      "The alternative operator // retains the first value, unless it is null, false, or empty (i.e. missing), in which case it takes on the second. Combined with the update operator |=, this can be contracted to //=.",
      "jq '.[] |= (.part_description //= .part)'",
      "To strictly update only in the case of null, i.e. to keep a value of false, and to not create the field if it's missing, the filter needs to check explicitly for null:",
      "jq '.[] |= ((select(has(\"part_description\")).part_description | select(. == null)) = .part)'",
      "then you would need to test for null rather than relying on // or //=.  So you could write:",
      "map( if has(\"part_description\") and .part_description == null then .part_description = .part else . end )"
    ],
    "utterance": "For objects where part_description is null, set part_description to the value of part.",
    "expressions": [
      ".[] |= (.part_description //= .part)",
      ".[] |= ((select(has(\"part_description\")).part_description | select(. == null)) = .part)",
      "map( if has(\"part_description\") and .part_description == null then .part_description = .part else . end )"
    ],
    "data": [
      {
        "input": [
          {
            "part": "brake-01982",
            "part_description": null
          }
        ],
        "output": [
          {
            "part": "brake-01982",
            "part_description": "brake-01982"
          }
        ]
      }
    ],
    "identifier": 71074641
  },
  {
    "context": [
      "I need to get:\r\n\r\n[\r\n  {\r\n    \"name\": \"name1\",\r\n    \"deceased\": \"1982-05-19\"\r\n  },\r\n  {\r\n    \"name\": \"name2\"\r\n  }\r\n]",
      "You can test for existence using `has`",
      "map(\r\n  {name} +\r\n  if has(\"deceased\")\r\n  then {deceased: (.deceased | strptime(\"%Y/%m/%d\") | strftime(\"%F\"))}\r\n  else {}\r\n  end\r\n)",
      "map(\r\n  {name, deceased}\r\n  | .deceased |= (strings | strptime(\"%Y/%m/%d\") | strftime(\"%F\"))\r\n)"
    ],
    "utterance": "For each object in an array, output the name and, if present, the deceased date reformatted from YYYY/MM/DD to YYYY-MM-DD; omit deceased if not present.",
    "expressions": [
      "map({name} + if has(\"deceased\") then {deceased: (.deceased | strptime(\"%Y/%m/%d\") | strftime(\"%F\"))} else {} end)",
      "map({name, deceased} | .deceased |= (strings | strptime(\"%Y/%m/%d\") | strftime(\"%F\")))"
    ],
    "data": [
      {
        "input": [
          {
            "name": "name1",
            "birth": "1950/05/05",
            "deceased": "1982/05/19"
          },
          {
            "name": "name2",
            "birth": "1982/05/19"
          }
        ],
        "output": [
          {
            "name": "name1",
            "deceased": "1982-05-19"
          },
          {
            "name": "name2"
          }
        ]
      }
    ],
    "identifier": 71079430
  },
  {
    "context": [
      "Problem here, is that sometimes some input objects doesn't contains .\"parent-identifier-value\", and I'm getting:\n\n> jq: error (at rsan.json:7): Cannot index object with null",
      "If its output should be\n\n{\n  \"identifier-value\": \"61\",\n  \"name\": \"name61\"\n}\n{\n  \"id\": \"62\",\n  \"name\": \"name62\",\n  \"parent-identifier-value\": \"61\",\n  \"partOf\": \"be8a02b6-54b9-450f-bf45-f28ab7ebf2dd\"\n}\n\nthen you can use\n\nif .\"parent-identifier-value\" then\n   .partOf = $dict[.\"parent-identifier-value\"]\nelse\n   .\nend",
      ".\"parent-identifier-value\" as $piv |\nif $piv then .partOf = $dict[$piv] else . end"
    ],
    "utterance": "Set the field partOf to the corresponding value from $dict using the object's parent-identifier-value field if it exists; otherwise, leave the object unchanged.",
    "expressions": [
      "if .\"parent-identifier-value\" then .partOf = $dict[.\"parent-identifier-value\"] else . end",
      ".\"parent-identifier-value\" as $piv | if $piv then .partOf = $dict[$piv] else . end"
    ],
    "data": [
      {
        "input": [
          {
            "identifier-value": "61",
            "name": "name61"
          },
          {
            "id": "62",
            "name": "name62",
            "parent-identifier-value": "61"
          }
        ],
        "output": [
          {
            "identifier-value": "61",
            "name": "name61"
          },
          {
            "id": "62",
            "name": "name62",
            "parent-identifier-value": "61",
            "partOf": "be8a02b6-54b9-450f-bf45-f28ab7ebf2dd"
          }
        ]
      }
    ],
    "identifier": 71076786
  },
  {
    "context": [
      "Is it possible convert JSON usinq jq to CSV in format where keys are first row and values second? Result should be like this\n\ndhcp-libs,12:4.2.5-83.el7.centos.1\nperl-Time-Local,1.2300-2.el7\nkbd-legacy,1.15.5-15.el7\nperl-Scalar-List-Utils,1.27-248.el7\nncurses-base,5.9-14.20130511.el7_4\n....",
      "jq -r '.[] | to_entries[] | [.[]] | @csv'",
      "If you don't want the quotes, you could use `join(\",\")` instead of `@csv` but this wouldn't do any escaping either:\n\njq -r '.[] | to_entries[] | [.[]] | join(\",\")'",
      "jq -r '.[] | to_entries[] | [ .key, .value ] | join(\",\")'"
    ],
    "utterance": "List each package name and its version as comma-separated key-value pairs, with one pair per line.",
    "expressions": [
      ".[] | to_entries[] | [ .key, .value ] | join(\",\")",
      ".[] | to_entries[] | [.[]] | join(\",\")",
      ".[] | to_entries[] | [.[]] | @csv"
    ],
    "data": [
      {
        "input": {
          "server1": {
            "dhcp-libs": "12:4.2.5-83.el7.centos.1",
            "perl-Time-Local": "1.2300-2.el7",
            "kbd-legacy": "1.15.5-15.el7",
            "perl-Scalar-List-Utils": "1.27-248.el7",
            "ncurses-base": "5.9-14.20130511.el7_4",
            "firewalld": "0.6.3-13.el7_9",
            "perl-threads": "1.87-4.el7",
            "aic94xx-firmware": "30-6.el7",
            "kpartx": "0.4.9-135.el7_9",
            "perl-Getopt-Long": "2.40-3.el7",
            "basesystem": "10.0-7.el7.centos",
            "rsyslog": "8.24.0-57.el7_9.1",
            "libtirpc": "0.2.4-0.16.el7",
            "python3-libs": "3.6.8-18.el7",
            "btrfs-progs": "4.9.1-1.el7",
            "ncurses-libs": "5.9-14.20130511.el7_4",
            "python36-m2crypto": "0.35.2-5.el7"
          }
        },
        "output": [
          "dhcp-libs,12:4.2.5-83.el7.centos.1",
          "perl-Time-Local,1.2300-2.el7",
          "kbd-legacy,1.15.5-15.el7",
          "perl-Scalar-List-Utils,1.27-248.el7",
          "ncurses-base,5.9-14.20130511.el7_4",
          "firewalld,0.6.3-13.el7_9",
          "perl-threads,1.87-4.el7",
          "aic94xx-firmware,30-6.el7",
          "kpartx,0.4.9-135.el7_9",
          "perl-Getopt-Long,2.40-3.el7",
          "basesystem,10.0-7.el7.centos",
          "rsyslog,8.24.0-57.el7_9.1",
          "libtirpc,0.2.4-0.16.el7",
          "python3-libs,3.6.8-18.el7",
          "btrfs-progs,4.9.1-1.el7",
          "ncurses-libs,5.9-14.20130511.el7_4",
          "python36-m2crypto,0.35.2-5.el7"
        ]
      }
    ],
    "identifier": 71063945
  },
  {
    "context": [
      "How to use jq to convert seconds since Unix epoch to a time string in human readable format but adjusted to Sydney, Australia time zone?",
      "If your timezone is different, set the shell's TZ variable accordingly before calling jq",
      "TZ=Australia/Sydney jq -n 'now | strflocaltime(\"%Y-%m-%dT%H:%M:%S\")'",
      "Both of the following convert to the time zone indicated by the `TZ` environment variable var:",
      "That uses your local time, as determined by `TZ` environment variable. Adjust as needed."
    ],
    "utterance": "Convert seconds since the Unix epoch to a human-readable time string adjusted to Sydney, Australia time zone.",
    "expressions": [
      "strflocaltime(\"%Y-%m-%dT%H:%M:%S\")",
      "localtime | strftime(\"%Y-%m-%dT%H:%M:%S\")"
    ],
    "identifier": 71106182
  },
  {
    "context": [
      "I want to map Core with its \"input\" temperature (tempX_input).",
      "**Result:**\n{\n  \"Core 0\": \"52.000\",\n  \"Core 1\": \"53.000\"\n}",
      "You could use:\nwith_entries(.value |= (with_entries(select(.key | endswith(\"_input\"))) | to_entries[].value ))",
      "Using with_enries so we can get the desired keys using endswith(\"_input\")",
      "Using regular expression :\n\njq 'map_values(\n        to_entries[] |\n        select(.key |\n                test(\"temp[[:digit:]]+_input\")).value\n    )' input.json"
    ],
    "utterance": "Return an object mapping each core key to the value of the attribute whose key ends with _input.",
    "expressions": [
      "with_entries(.value |= (with_entries(select(.key | endswith(\"_input\"))) | to_entries[].value ))",
      "map_values(\n        to_entries[] |\n        select(.key |\n                test(\"temp[[:digit:]]+_input\")).value\n    )"
    ],
    "data": [
      {
        "input": {
          "Core 0": {
            "temp2_input": "52.000",
            "temp2_max": "100.000",
            "temp2_crit": "100.000",
            "temp2_crit_alarm": "0.000"
          },
          "Core 1": {
            "temp3_input": "53.000",
            "temp3_max": "100.000",
            "temp3_crit": "100.000",
            "temp3_crit_alarm": "0.000"
          }
        },
        "output": {
          "Core 0": "52.000",
          "Core 1": "53.000"
        }
      }
    ],
    "identifier": 71092471
  },
  {
    "context": [
      "Suppose I have a file fruit.json containing the following lines:",
      "[{\"name\": \"apple\",\"color\": \"red\",\"price\": 20},{\"name\": \"banana\",\"color\": \"yellow\",\"price\": 15},{\"name\": \"pineapple\",\"color\": \"orange\",\"price\": 53}]",
      "If I do `jq '. | map(.)' fruit.json` then I get the original data. That's expected.",
      "However if I do `jq '.[] | map(.)' fruit.json` then I get this: [\"apple\",\"red\",20] [\"banana\",\"yellow\",15] [\"pineapple\",\"orange\",53]",
      "The `[]` after `.` strips away the brackets from the input array.",
      "When given an array or object, `.[]` produces the values of the elements of that array or object.",
      "`map( ... )` is equivalent to [ .[] | ... ]",
      "For an array, that means map( . ) \u2261 [ .[0], .[1], ... ] \u2261 .",
      "For an object, that means map( . ) \u2261 [ .[\"key1\"], .[\"key2\"], ... ]",
      "We call that a stream.",
      ".[] produces the values of the array or object given to it."
    ],
    "utterance": "Output each fruit object's values as an array, one per line.",
    "expressions": [
      ".[] | map(.)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "apple",
            "color": "red",
            "price": 20
          },
          {
            "name": "banana",
            "color": "yellow",
            "price": 15
          },
          {
            "name": "pineapple",
            "color": "orange",
            "price": 53
          }
        ],
        "output": [
          [
            "apple",
            "red",
            20
          ],
          [
            "banana",
            "yellow",
            15
          ],
          [
            "pineapple",
            "orange",
            53
          ]
        ]
      }
    ],
    "identifier": 71075281
  },
  {
    "context": [
      "JOIN(INDEX($customers[]; .CustomerID); $orders[]; .CustomerIDRef;\n  \"\\(.[0].OrderID): \\(.[1].CustomerName) ordered Product #\\(.[0].ProductIDRef).\"\n)",
      "10: Bill ordered Product #7.\n11: Alfred ordered Product #7.\n12: Bill ordered Product #14.\n13: Bill ordered Product #7."
    ],
    "utterance": "For each order, produce a string in the format '<OrderID>: <CustomerName> ordered Product #<ProductIDRef>.'",
    "expressions": [
      "JOIN(INDEX($customers[]; .CustomerID); $orders[]; .CustomerIDRef; \"\\(.[0].OrderID): \\(.[1].CustomerName) ordered Product #\\(.[0].ProductIDRef).\")"
    ],
    "data": [
      {
        "input": {
          "orders": [
            {
              "OrderID": "10",
              "CustomerIDRef": "2",
              "ProductIDRef": "7"
            },
            {
              "OrderID": "11",
              "CustomerIDRef": "1",
              "ProductIDRef": "7"
            },
            {
              "OrderID": "12",
              "CustomerIDRef": "2",
              "ProductIDRef": "14"
            },
            {
              "OrderID": "13",
              "CustomerIDRef": "2",
              "ProductIDRef": "7"
            }
          ],
          "customers": [
            {
              "CustomerID": "1",
              "CustomerName": "Alfred"
            },
            {
              "CustomerID": "2",
              "CustomerName": "Bill"
            },
            {
              "CustomerID": "3",
              "CustomerName": "Caroline"
            }
          ]
        },
        "output": [
          "10: Bill ordered Product #7.",
          "11: Alfred ordered Product #7.",
          "12: Bill ordered Product #14.",
          "13: Bill ordered Product #7."
        ]
      }
    ],
    "identifier": 71106595
  },
  {
    "context": [
      "How can I verify that values is empty, referred to my example?   \r\nI want to avoid any iteration on empty values.   \r\nIs there any way to verify the existing key with jq, that should not be empty?",
      "The goal I would like to achieve is something like **redirected at the end of a file**\r\n\r\n    key2:\r\n    - first_value\r\n    - second_value\r\n\r\nin case of key, since it is empty I don&#39;t want to have any results",
      "This discards all items with an empty array, and iterates over the rest printing out the key name, then all array items.\r\n\r\n~~~sh\r\njq -r 'to_entries[] | select(.value | length > 0) | .key, \"- \\(.value[])\"'\r\n~~~\r\n~~~\r\nkey2\r\n- first_value\r\n- second_value\r\n~~~"
    ],
    "utterance": "Print only keys with non-empty array values, listing the key and each array item as '- item', and omit keys whose array is empty.",
    "expressions": [
      "to_entries[] | select(.value | length > 0) | .key, \"- \\(.value[])\""
    ],
    "data": [
      {
        "input": {
          "key1": [],
          "key2": [
            "first_value",
            "second_value"
          ]
        },
        "output": "key2\n- first_value\n- second_value"
      }
    ],
    "identifier": 71111424
  },
  {
    "context": [
      "but I need it to look like this:\r\n\r\n    {\"user_id\": 123, \"value\": 99}\r\n    {\"user_id\": 122, \"value\": 100}\r\n\r\nBasically every set of curly brackets should be on its own line.",
      "just use jq's `--compact-output` (or `-c`) option and the [identity filter](https://stedolan.github.io/jq/manual/v1.6/#Identity:.) `.`.",
      "jq -csR '\"[\\(.)]\" | fromjson |.[]' old.txt"
    ],
    "utterance": "Print each object with user_id and value on a single line, placing each set of curly brackets on its own line.",
    "expressions": [
      ".",
      ".[]"
    ],
    "data": [
      {
        "input": [
          {
            "user_id": 123,
            "value": 99
          },
          {
            "user_id": 122,
            "value": 100
          }
        ],
        "output": [
          {
            "user_id": 123,
            "value": 99
          },
          {
            "user_id": 122,
            "value": 100
          }
        ]
      }
    ],
    "identifier": 71116214
  },
  {
    "context": [
      "I want to use parameters/environment variables to dynamically add an object to that JSON object using `jq`",
      "wherein `aiops`, `catalog_source` and `channel` are parameterized by environment variables in this way:",
      "jq --arg parent_key aiops \\",
      "   --arg child_key catalog_source \\",
      "   --arg child_val abc.com/123 \\",
      "   '.[$parent_key] += {($child_key): $child_val}' input.json"
    ],
    "utterance": "Add a new key whose name and child key-value are provided dynamically via variables, such as adding an aiops object with catalog_source set to abc.com/123.",
    "expressions": [
      ".[$parent_key] += {($child_key): $child_val}"
    ],
    "data": [
      {
        "input": {
          "cluster": "bvt-rtp-123",
          "state": "installed",
          "timestamp": "2022-02-14T10:23:01Z"
        },
        "output": {
          "cluster": "bvt-rtp-123",
          "state": "installed",
          "timestamp": "2022-02-14T10:23:01Z",
          "aiops": {
            "catalog_source": "abc.com/123"
          }
        }
      }
    ],
    "identifier": 71112010
  },
  {
    "context": [
      "getting new line value while parsing json file with space in value from shell script",
      "for s in $(cat $dir | jq -r \"to_entries|map(\\\"\\(.key)=\\(.value|tostring)\\\")|.[]\" ); do",
      "KAFKASTORE_SASL_JAAS_CONFIG=software.amazon.msk.auth.iam.IAMLoginModule",
      "required; ./jq.sh: line 20: export: `required;': not a valid identifier",
      "while read -r s; do\n       export \"$s\"\n  done < <(jq -r 'to_entries|map(\"\\(.key)=\\(.value)\")[]' \"$file\")"
    ],
    "utterance": "Create key=value pairs for each entry where values may contain spaces or special characters, outputting each on a single line.",
    "expressions": [
      "to_entries | map(\"\\(.key)=\\(.value)\")[]"
    ],
    "data": [
      {
        "input": {
          "KAFKASTORE_SASL_JAAS_CONFIG": "software.amazon.msk.auth.iam.IAMLoginModule required;",
          "CLASSPATH": "/usr/share/java/aws/*"
        },
        "output": [
          "KAFKASTORE_SASL_JAAS_CONFIG=software.amazon.msk.auth.iam.IAMLoginModule required;",
          "CLASSPATH=/usr/share/java/aws/*"
        ]
      }
    ],
    "identifier": 71114895
  },
  {
    "context": [
      "If I only want to keep the amd64 and arm64 architectures in the manifest file, how should I write this command?",
      "You should use `or` instead of `and` since a field can only have one of those options (if at all), never both.",
      ".manifests |= map(select(.platform.architecture == \"arm64\" or .platform.architecture == \"amd64\"))",
      ".manifests |= map(select(IN(.platform.architecture; \"arm64\", \"amd64\")))",
      "Output",
      "{\n  \"schemaVersion\": 2,\n  \"mediaType\": \"application/vnd.docker.distribution.manifest.list.v2+json\",\n  \"manifests\": [\n    {\n      \"mediaType\": \"application/vnd.docker.distribution.manifest.v2+json\",\n      \"size\": 1785,\n      \"digest\": \"sha256:34860ea294a018d392e61936f19a7862d5e92039d196cac9176da14b2bbd0fe3\",\n      \"platform\": {\n        \"architecture\": \"amd64\",\n        \"os\": \"linux\"\n      }\n    },\n    {\n      \"mediaType\": \"application/vnd.docker.distribution.manifest.v2+json\",\n      \"size\": 1996,\n      \"digest\": \"sha256:a0000b627744766025f552c4db171a00b055d5d709f22aec8be96b6375b220cf\",\n      \"platform\": {\n        \"architecture\": \"arm64\",\n        \"os\": \"linux\"\n      }\n    }\n  ]\n}"
    ],
    "utterance": "Keep only manifests with architecture set to amd64 or arm64 in the list.",
    "expressions": [
      ".manifests |= map(select(.platform.architecture == \"arm64\" or .platform.architecture == \"amd64\"))",
      ".manifests |= map(select(IN(.platform.architecture; \"arm64\", \"amd64\")))"
    ],
    "data": [
      {
        "input": {
          "schemaVersion": 2,
          "mediaType": "application/vnd.docker.distribution.manifest.list.v2+json",
          "manifests": [
            {
              "mediaType": "application/vnd.docker.distribution.manifest.v2+json",
              "size": 1785,
              "digest": "sha256:34860ea294a018d392e61936f19a7862d5e92039d196cac9176da14b2bbd0fe3",
              "platform": {
                "architecture": "amd64",
                "os": "linux"
              }
            },
            {
              "mediaType": "application/vnd.docker.distribution.manifest.v2+json",
              "size": 1996,
              "digest": "sha256:93d5f2293f6faf76fc3f2ff30628cf2100b68e3cf16901f39f01d449e67f67d9",
              "platform": {
                "architecture": "arm",
                "os": "linux"
              }
            },
            {
              "mediaType": "application/vnd.docker.distribution.manifest.v2+json",
              "size": 1996,
              "digest": "sha256:a0000b627744766025f552c4db171a00b055d5d709f22aec8be96b6375b220cf",
              "platform": {
                "architecture": "arm64",
                "os": "linux"
              }
            },
            {
              "mediaType": "application/vnd.docker.distribution.manifest.v2+json",
              "size": 1995,
              "digest": "sha256:227c06dc0468dacfcfc04cc0aad3f5138a51bb2afa4d8252c6e83ca39beb8c6f",
              "platform": {
                "architecture": "ppc64le",
                "os": "linux"
              }
            },
            {
              "mediaType": "application/vnd.docker.distribution.manifest.v2+json",
              "size": 1996,
              "digest": "sha256:e7cfbfe13f7a179277f55a835abc0b01f9c6c21892c1ae1b0007f2e09777bca0",
              "platform": {
                "architecture": "s390x",
                "os": "linux"
              }
            }
          ]
        },
        "output": {
          "schemaVersion": 2,
          "mediaType": "application/vnd.docker.distribution.manifest.list.v2+json",
          "manifests": [
            {
              "mediaType": "application/vnd.docker.distribution.manifest.v2+json",
              "size": 1785,
              "digest": "sha256:34860ea294a018d392e61936f19a7862d5e92039d196cac9176da14b2bbd0fe3",
              "platform": {
                "architecture": "amd64",
                "os": "linux"
              }
            },
            {
              "mediaType": "application/vnd.docker.distribution.manifest.v2+json",
              "size": 1996,
              "digest": "sha256:a0000b627744766025f552c4db171a00b055d5d709f22aec8be96b6375b220cf",
              "platform": {
                "architecture": "arm64",
                "os": "linux"
              }
            }
          ]
        }
      }
    ],
    "identifier": 71106503
  },
  {
    "context": [
      "but I want to get the whole lines of code. (Not a part of it)",
      "( .rules[] | select(.xxx.url == \"https://google.com\") | .xxx ) += {\"pass\": \"abc\"}",
      ".rules.ccc.xxx.pass = \"abc\""
    ],
    "utterance": "Add a key \"pass\" with value \"abc\" to the xxx object where the url is \"https://google.com\", and return the full modified structure.",
    "expressions": [
      "( .rules[] | select(.xxx.url == \"https://google.com\") | .xxx ) += {\"pass\": \"abc\"}",
      ".rules.ccc.xxx.pass = \"abc\"",
      "walk(if type==\"object\" and (.url|type)==\"string\" and (.url|endswith(\"google.com\")) then .pass = \"abc\" else . end)"
    ],
    "data": [
      {
        "input": {
          "rules": {
            "aaa": {
              "xxx": {
                "url": "https://microsoft.com"
              },
              "xxxx": {
                "url": "https://netflix.com"
              }
            },
            "bbb": {
              "xxx": {
                "url": "https://amazon.com"
              }
            },
            "ccc": {
              "xxx": {
                "url": "https://google.com"
              }
            }
          }
        },
        "output": {
          "rules": {
            "aaa": {
              "xxx": {
                "url": "https://microsoft.com"
              },
              "xxxx": {
                "url": "https://netflix.com"
              }
            },
            "bbb": {
              "xxx": {
                "url": "https://amazon.com"
              }
            },
            "ccc": {
              "xxx": {
                "url": "https://google.com",
                "pass": "abc"
              }
            }
          }
        }
      }
    ],
    "identifier": 71121734
  },
  {
    "context": [
      "label $out | reduce .[] as $item (0; if $item==1 then break $out else .+$item end)",
      "Input:\n[3,2,1]",
      "I was expecting output 5.",
      "You can still capture `empty` though, for instance\nlabel $out | reduce .[] as $item (0;\n  if $item == 1 then break $out else . + $item end\n)? // (.[:index(1)] | add)",
      "From the [manual]():\n> The `break $label_name` expression will cause the program to to act as though the nearest (to the left) `label $label_name` produced `empty`.",
      "if you replace `reduce` with `foreach`, the result is as expected"
    ],
    "utterance": "Sum array elements until the first occurrence of 1 is reached, then stop and return the sum of the preceding elements.",
    "expressions": [
      "(.[:index(1)] | add)"
    ],
    "data": [
      {
        "input": [
          3,
          2,
          1
        ],
        "output": 5
      }
    ],
    "identifier": 71135312
  },
  {
    "context": [
      "How can I use jq to read *updates.json* and apply its content to *content.json*? ... The jq script must be smart enough to just apply whatever it finds.",
      "The output should be:\n{\n  \"Type\": {\n    \"OS\": \"Windows\"\n  },\n  \"Network\": {\n     \"Protocol\": \"HTTP\",\n     \"Port\": 80\n  }\n}",
      "Perhaps the \"recursive addition\" operator `*` will meet your needs:\n< contents.json  jq --argfile updates updates.json '\n  . * $updates\n'"
    ],
    "utterance": "Merge the values from updates.json into content.json so that missing fields are preserved and existing fields are overwritten by updates.json.",
    "expressions": [
      ". * $updates",
      "def multiply:reduce .[] as $i ({}; . * $i); multiply"
    ],
    "data": [
      {
        "input": {
          "content.json": {
            "Type": {
              "OS": "Windows"
            },
            "Network": {
              "Protocol": "unknown",
              "Port": 80
            }
          },
          "updates.json": {
            "Network": {
              "Protocol": "HTTP"
            }
          }
        },
        "output": {
          "Type": {
            "OS": "Windows"
          },
          "Network": {
            "Protocol": "HTTP",
            "Port": 80
          }
        }
      }
    ],
    "identifier": 71132774
  },
  {
    "context": [
      "I'm trying to insert the content of a long html file to my json file using the command ...",
      "jq --slurpfile texts <(jq -Rs file.html) '.body=$texts[0]' file.json >newfile.json",
      "however, I'm getting this error ... jq: error: file/0 is not defined at <top-level>",
      "You're missing a filter in the inner jq call. Insert the [identity filter](https://stedolan.github.io/jq/manual/v1.6/#Identity:.) `.` as in `jq -Rs . file.html`:",
      "jq --slurpfile texts <(jq -Rs . file.html) '.body=$texts[0]' file.json >newfile.json",
      "You could also use `--argfile` instead of `--slurpfile` which gives you the string itself rather than an array...",
      "jq --argfile texts <(jq -Rs . file.html) '.body=$texts' file.json >newfile.json",
      "if you are using jq 1.6, there's yet an easier way to do it. Use `--rawfile` instead of `--argfile` or `--slurpfile` and you don't need the other jq at all anymore:",
      "jq --rawfile texts file.html '.body=$texts' file.json >newfile.json"
    ],
    "utterance": "Set the 'body' key in the file to the full content of a local file named file.html, preserving the file content as a string value.",
    "expressions": [
      "jq --slurpfile texts <(jq -Rs . file.html) '.body=$texts[0]' file.json >newfile.json",
      "jq --argfile texts <(jq -Rs . file.html) '.body=$texts' file.json >newfile.json",
      "jq --rawfile texts file.html '.body=$texts' file.json >newfile.json"
    ],
    "identifier": 71125191
  },
  {
    "context": [
      "All values of the bash-array are saved to EVERY element. It's supposed to be just one value per json-object - actually as an array itself.",
      "So in pseudo: \"pushintojson[0]\" needs to be under \"features[0]\", pushintojson[1]\" to \"features[1]\"\npushintojson[2]\" to \"features[2]\" etc.",
      "One way, which is closer to your attempt, is to expand the `.features` array using `to_entries` to fit the array's elements  with their keys, which in turn can be used within `map` to reference by index the corresponding item of the `$ARGS.positional` array.",
      "Another approach would be to use `transpose` to generate an array of aligned items from both initial arrays, and then again just `map` their contents together."
    ],
    "utterance": "Attach each value from a positional array to the corresponding object within the features array, placing it as the NOSW property under properties.",
    "expressions": [
      ".features |= (to_entries | map(.value * {properties: {NOSW: $ARGS.positional[.key]}}))",
      ".features |= ([., $ARGS.positional] | transpose | map(.[0] * {properties: {NOSW: .[1]}}))"
    ],
    "data": [
      {
        "input": {
          "type": "FeatureCollection",
          "name": "test",
          "features": [
            {
              "type": "Feature",
              "properties": {
                "OBJECTID": 3213,
                "USE": "dem",
                "tile": "4045644"
              }
            },
            {
              "type": "Feature",
              "properties": {
                "OBJECTID": 3214,
                "USE": "dem",
                "tile": "4045646"
              }
            },
            {
              "type": "Feature",
              "properties": {
                "OBJECTID": 3215,
                "USE": "dem",
                "tile": "4045648"
              }
            }
          ]
        },
        "output": {
          "type": "FeatureCollection",
          "name": "test",
          "features": [
            {
              "type": "Feature",
              "properties": {
                "OBJECTID": 3213,
                "USE": "dem",
                "tile": "4045644",
                "NOSW": "4045646 NV NV NV"
              }
            },
            {
              "type": "Feature",
              "properties": {
                "OBJECTID": 3214,
                "USE": "dem",
                "tile": "4045646",
                "NOSW": "4045648 NV 4045644 NV"
              }
            },
            {
              "type": "Feature",
              "properties": {
                "OBJECTID": 3215,
                "USE": "dem",
                "tile": "4045648",
                "NOSW": "4045650 NV 4045646 NV"
              }
            }
          ]
        }
      }
    ],
    "identifier": 71105669
  },
  {
    "context": [
      "jq '.thermostatList[] | {name, identifier}' test.json",
      "What I'd like",
      "{\n   \"thermostats\": [\n      {\n         \"name\": \"Thermostat\",\n         \"identifier\": 123456789\n      }\n   ]\n}",
      "Take `thermostatList` as context and `map`:",
      "jq '.thermostatList | {thermostats: map({name, identifier})}' test.json"
    ],
    "utterance": "Extract the name and identifier fields from each item in thermostatList and wrap them in an object under the thermostats key as an array.",
    "expressions": [
      ".thermostatList | {thermostats: map({name, identifier})}"
    ],
    "data": [
      {
        "input": {
          "thermostatList": [
            {
              "name": "Thermostat",
              "identifier": 123456789,
              "otherField": "foo"
            }
          ]
        },
        "output": {
          "thermostats": [
            {
              "name": "Thermostat",
              "identifier": 123456789
            }
          ]
        }
      }
    ],
    "identifier": 71135417
  },
  {
    "context": [
      "An example of search that I&#39;m trying to do is: \r\n```\r\nselect item.name where owner.id = \"67890\"\r\n```\r\nand the expected output would be:\r\n```\r\nitem.name = \"sedan\"\r\n```",
      "Everything combined in a jq call would be:\r\n~~~sh\r\njq '.data.inventory.list.content[] | select(.owner.id == \"67890\").item.name'\r\n~~~\r\n~~~\r\n\"sedan\"\r\n~~~",
      "or more succinctly:\r\n\r\n```\r\n..|objects|select(.owner.id? == \"67890\").item.name\r\n```\r\n"
    ],
    "utterance": "Return the item name where the owner's id is \"67890\".",
    "expressions": [
      ".data.inventory.list.content[] | select(.owner.id == \"67890\").item.name",
      "..|objects|select(.owner.id? == \"67890\").item.name"
    ],
    "data": [
      {
        "input": {
          "data": {
            "inventory": {
              "location": "remote",
              "list": {
                "content": [
                  {
                    "item": {
                      "name": "minivan"
                    },
                    "owner": {
                      "id": "12345",
                      "state": "CA"
                    }
                  },
                  {
                    "item": {
                      "name": "sedan"
                    },
                    "owner": {
                      "id": "67890",
                      "state": "AZ"
                    }
                  }
                ]
              }
            }
          }
        },
        "output": "sedan"
      }
    ],
    "identifier": 71138293
  },
  {
    "context": [
      "I want to get key-value pair objects based on their role. In this example there are 3 roles(Presenter, Approver, Customer) but there can be more as it is dynamic.",
      "Expected output using jq, map,",
      "{\n\t\"Presenter\": {\n\t  \"email_address\": \"roney@domain.com\",\n\t  \"name\": \"Roney\",\n\t  \"role\": \"Presenter\"\n\t},\n\t\"Approver\": {\n\t  \"email_address\": \"tim@domain.com\",\n\t  \"name\": \"Tim\",\n\t  \"role\": \"Approver\"\n\t},\n\t\"Customer\": {\n\t  \"email_address\": \"alex@domain.com\",\n\t  \"name\": \"Alex\",\n\t  \"role\": \"Customer\"\n\t}\n}",
      "Then it assigns the three fields to their values accordingly, using `reduce` to combine the grouping.",
      "`split`s the keys at the space character while discarding any items that don\u2019t have one in it.",
      "Here\u2019s another, shorter approach that doesn\u2019t use `group_by`. Instead, this directly iterates over the initial object using `reduce` and immediately sets all the fields accordingly if the key followed the space-separated role-key pattern."
    ],
    "utterance": "Extract all role-specific objects, keyed by role, each containing name, email_address, and role, using role and key inferred from input field names with format '<Role> Name' or '<Role> Email'.",
    "expressions": [
      "to_entries\n| map(.key |= split(\" \") | select(.key[1]))\n| reduce group_by(.key[0])[] as $g ({};\n    .[$g[0].key[0]] = (\n      INDEX($g[]; .key[1]) | {\n        email_address: .Email.value,\n        name: .Name.value,\n        role: .Name.key[0]\n      }\n    )\n  )",
      "{ \"Name\": \"name\",  \"Email\": \"email_address\" } as $key_map |\nto_entries |\nmap (\n   ( .key | split(\" \") | select( length == 2 ) ) as [ $role, $raw_key ] |\n   [ $role, \"role\",             $role  ],\n   [ $role, $key_map[$raw_key], .value ]\n) |\nreduce .[] as [ $role, $key, $val ] ( {}; .[ $role ][ $key ] = $val )",
      "reduce (to_entries[] | .key /= \" \") as {key: [$role, $key], $value} ({};\n  if $key then\n    .[$role] += {({Email: \"email_address\", Name: \"name\"}[$key]): $value, $role}\n  else . end\n)"
    ],
    "data": [
      {
        "input": {
          "Presenter Name": "Roney",
          "Presenter Email": "roney@domain.com",
          "Approver Name": "Tim",
          "Approver Email": "tim@domain.com",
          "Customer Name": "Alex",
          "Customer Email": "alex@domain.com",
          "Invoice": "001",
          "Date": "2022-02-14"
        },
        "output": {
          "Presenter": {
            "email_address": "roney@domain.com",
            "name": "Roney",
            "role": "Presenter"
          },
          "Approver": {
            "email_address": "tim@domain.com",
            "name": "Tim",
            "role": "Approver"
          },
          "Customer": {
            "email_address": "alex@domain.com",
            "name": "Alex",
            "role": "Customer"
          }
        }
      }
    ],
    "identifier": 71103776
  },
  {
    "context": [
      "I want to update the .authentication.anonymous.enabled value with the boolean _false_",
      "jq --arg new false '.authentication.anonymous.enabled |= $new' config.json",
      "This updates the value to _false_ but it does so as a string, rather than a boolean.",
      "Use `--argjson` for JSON parameters.",
      "jq --argjson new false '.authentication.anonymous.enabled = $new' config.json"
    ],
    "utterance": "Set the value at .authentication.anonymous.enabled to the boolean false.",
    "expressions": [
      "jq --argjson new false '.authentication.anonymous.enabled = $new' config.json"
    ],
    "data": [
      {
        "input": {
          "kind": "KubeletConfiguration",
          "apiVersion": "kubelet.config.k8s.io/v1beta1",
          "address": "0.0.0.0",
          "authentication": {
            "anonymous": {
              "enabled": true
            },
            "webhook": {
              "cacheTTL": "2m0s",
              "enabled": true
            },
            "x509": {
              "clientCAFile": "/etc/kubernetes/pki/ca.crt"
            }
          },
          "authorization": {
            "mode": "Webhook",
            "webhook": {
              "cacheAuthorizedTTL": "5m0s",
              "cacheUnauthorizedTTL": "30s"
            }
          }
        },
        "output": {
          "kind": "KubeletConfiguration",
          "apiVersion": "kubelet.config.k8s.io/v1beta1",
          "address": "0.0.0.0",
          "authentication": {
            "anonymous": {
              "enabled": false
            },
            "webhook": {
              "cacheTTL": "2m0s",
              "enabled": true
            },
            "x509": {
              "clientCAFile": "/etc/kubernetes/pki/ca.crt"
            }
          },
          "authorization": {
            "mode": "Webhook",
            "webhook": {
              "cacheAuthorizedTTL": "5m0s",
              "cacheUnauthorizedTTL": "30s"
            }
          }
        }
      }
    ],
    "identifier": 71146201
  },
  {
    "context": [
      "I want to extract objects name and their attributes (`.properties`) from `.definitions` part of swagger json file",
      "The point is `.properties` sometimes come directly after object name and sometimes as part of `allOf`, `anyOf`, or `oneOf`",
      "jq -r '\n  .definitions\n  | to_entries[]\n  | .key + \":\", \"  \" + (\n    .value\n    | (., .allOf[], .anyOf[], .oneOf[] | .properties)? // {}\n    | to_entries[].key\n  )\n'"
    ],
    "utterance": "List each object name in definitions followed by the names of its properties, including those under allOf, anyOf, or oneOf.",
    "expressions": [
      ".definitions\n| to_entries[]\n| .key + \":\", \"  \" + (\n    .value\n    | (., .allOf[], .anyOf[], .oneOf[] | .properties)? // {}\n    | to_entries[].key\n)"
    ],
    "data": [
      {
        "input": {
          "definitions": {
            "Pet": {
              "type": "object",
              "required": [
                "pet_type"
              ],
              "properties": {
                "pet_type": {
                  "type": "string"
                }
              },
              "discriminator": {
                "propertyName": "pet_type"
              }
            },
            "Dog": {
              "allOf": [
                {
                  "$ref": "#/components/schemas/Pet"
                },
                {
                  "type": "object",
                  "properties": {
                    "bark": {
                      "type": "boolean"
                    },
                    "breed": {
                      "type": "string",
                      "enum": [
                        "Dingo",
                        "Husky",
                        "Retriever",
                        "Shepherd"
                      ]
                    }
                  }
                }
              ]
            }
          }
        },
        "output": "Pet:\n  pet_type\nDog:\n  bark\n  breed"
      }
    ],
    "identifier": 71147392
  },
  {
    "context": [
      "Which JQ command should I use to get the result like this:\r\n\r\n    \"2254003131908096\": {\r\n      {\r\n        \"exchange\": \"39480500160\",\r\n        \"replication\": \"39763833120\"\r\n      }\r\n    }\r\n\t\r\n    \"2296334329577472\": {\r\n      {\r\n        \"exchange\": \"36713833920\",\r\n        \"replication\": \"39763833120\"\r\n      }\r\n    }\r\n  \r\n    \"2297708719112192\": {  \r\n      {\r\n        \"exchange\": \"39830499360\",\r\n        \"replication\": \"41430500640\"\r\n      }\r\n    }",
      "reduce (inputs / \" \" ) as [$k,$e,$r] ({}; .+{($k):{exchange:$e,replication:$r}})",
      "jq -Rn '\n  [inputs / \" \"] | reduce .[] as $line ({};\n    .[$line[0]] = {exchange: $line[1], replication: $line[2]}\n  )\n'"
    ],
    "utterance": "Transform lines containing three space-separated numbers into an object mapping the first number to an object with keys 'exchange' and 'replication' set to the second and third numbers, respectively.",
    "expressions": [
      "jq -Rn '[inputs / \" \"] | reduce .[] as $line ({}; .[$line[0]] = {exchange: $line[1], replication: $line[2]})'",
      "reduce (inputs / \" \" ) as [$k,$e,$r] ({}; .+{($k):{exchange:$e,replication:$r}})"
    ],
    "data": [
      {
        "input": "2254003131908096 39480500160 39763833120\n2296334329577472 36713833920 37747166400\n2297708719112192 39830499360 41430500640\n",
        "output": {
          "2254003131908096": {
            "exchange": "39480500160",
            "replication": "39763833120"
          },
          "2296334329577472": {
            "exchange": "36713833920",
            "replication": "37747166400"
          },
          "2297708719112192": {
            "exchange": "39830499360",
            "replication": "41430500640"
          }
        }
      }
    ],
    "identifier": 71142954
  },
  {
    "context": [
      "I need get following output with `jq`:\r\n\r\n    sys1    1.1.1.1 ent1\r\n    sys1    2.2.2.2 ent0\r\n    sys2    3.3.3.3 ent0\r\n",
      "Iterate outside the array which contains the `.name`. That way, another array is generated for each iteration step.",
      "If the objects in the `.interfaces` array can have more than just those two field, but you only want to output said two fields, name them explicitly.",
      "jq -r '[].system | [.name] + (.interfaces[]? | [.ip, .ent]) | @tsv'"
    ],
    "utterance": "For each system that has interfaces, output the system name, interface IP, and interface ent as tab-separated values, one line per interface.",
    "expressions": [
      ".[].system | [.name] + (.interfaces[]? | [.ip, .ent]) | @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "system": {
              "name": "sys1",
              "interfaces": [
                {
                  "ip": "1.1.1.1",
                  "ent": "ent1"
                },
                {
                  "ip": "2.2.2.2",
                  "ent": "ent0"
                }
              ]
            }
          },
          {
            "system": {
              "name": "sys2",
              "interfaces": [
                {
                  "ip": "3.3.3.3",
                  "ent": "ent0"
                }
              ]
            }
          },
          {
            "system": {
              "name": "sys3",
              "interfaces": null
            }
          },
          {
            "system": {
              "name": "sys4"
            }
          }
        ],
        "output": "sys1\t1.1.1.1\tent1\nsys1\t2.2.2.2\tent0\nsys2\t3.3.3.3\tent0"
      }
    ],
    "identifier": 71148913
  },
  {
    "context": [
      "the condition is that all ZIPCODES must belong to a specific list:\r\n\r\n      ['33410', '42000', '75015'....]",
      "the result should be like this (the output file must have the same structure as the input):",
      "If your computer has enough RAM, then the simplest solution would be along the lines of:\r\n```\r\n< very-large-file.json jq '\r\n  .listPoint |= map(select(.ZIPCODE|startswith(\"33\")))'\r\n```",
      "If you want to select zipcodes based on a whitelist, change the selection criterion e.g. to\r\n\r\n    .ZIPCODE|IN($whitelist[])\r\n",
      "jm --pointer /listPoint large.json |\r\n  jq -n '[\"33410\", \"42000\", \"75015\"] as $ok\n         | {listPoint: [inputs | select(.adress.ZIPCODE|IN($ok[]))]} '"
    ],
    "utterance": "Filter all objects in 'listPoint' so that only entries where 'adress.ZIPCODE' is in ['33410', '42000', '75015'] remain, preserving the overall structure.",
    "expressions": [
      "[\"33410\", \"42000\", \"75015\"] as $ok | .listPoint |= map(select(.adress.ZIPCODE|IN($ok[])))",
      "jq -n '[\"33410\", \"42000\", \"75015\"] as $ok | {listPoint: [inputs | select(.adress.ZIPCODE|IN($ok[]))]}'"
    ],
    "data": [
      {
        "input": {
          "listPoint": [
            {
              "Paime": "RE6845",
              "rmOi": "SNO-55",
              "State": "OPEN",
              "dateOpneing": "2017-12-22",
              "adress": {
                "ZIPCODE": "33410",
                "codeRoc": "33105"
              }
            },
            {
              "Paime": "RE6243",
              "rmOi": "SNO-65",
              "State": "OPEN",
              "dateOpneing": "2014-11-12",
              "adress": {
                "ZIPCODE": "453410",
                "codeRoc": "35105"
              }
            }
          ]
        },
        "output": {
          "listPoint": [
            {
              "Paime": "RE6845",
              "rmOi": "SNO-55",
              "State": "OPEN",
              "dateOpneing": "2017-12-22",
              "adress": {
                "ZIPCODE": "33410",
                "codeRoc": "33105"
              }
            }
          ]
        }
      }
    ],
    "identifier": 71146786
  },
  {
    "context": [
      "This command `jq \".[]|keys\" config.json` gives following output:\n\n    [\n      \"N1\",\n      \"N2\"\n    ]\n    [\n      \"N3\",\n      \"N4\"\n    ]",
      "What I ideally want is very simple:\n\n    [\"N1\", \"N2\", \"N3\", \"N4\"]",
      "Use `map` instead:\n~~~sh\njq 'map(keys[])' config.json\n~~~\n~~~json\n[\n  \"N1\",\n  \"N2\",\n  \"N3\",\n  \"N4\"\n]\n~~~",
      "Note that `keys` sorts the keys. If you want them unsorted, use `keys_unsorted` instead."
    ],
    "utterance": "Combine all nested object keys from top-level properties into a single flat array.",
    "expressions": [
      "map(keys[])",
      "map(keys_unsorted[])"
    ],
    "data": [
      {
        "input": {
          "Test1": {
            "N1": {
              "crn": "1",
              "con": "2"
            },
            "N2": {
              "crn": "100",
              "con": "200"
            }
          },
          "test2": {
            "N3": {
              "crn": "xx",
              "con": "2x"
            },
            "N4": {
              "crn": "xxxx",
              "con": "3xx"
            }
          }
        },
        "output": [
          "N1",
          "N2",
          "N3",
          "N4"
        ]
      }
    ],
    "identifier": 71149572
  },
  {
    "context": [
      "My json query string was off.\nIt was\n{\"selection\":{\"selectionType\":\"thermostats\",\"selectionMatch\":123456789,\"thermostat\":{\"settings\":{\"humidity\":45}}}}\nand should have been:\n{\"selection\":{\"selectionType\":\"thermostats\",\"selectionMatch\":123456789},\"thermostat\":{\"settings\":{\"humidity\":45}}}\n",
      "'thermostat' should have been at the top level instead of under 'selection'"
    ],
    "utterance": "Move the 'thermostat' key to the top level, alongside 'selection', instead of nesting it within 'selection'.",
    "expressions": [
      ". as $in | { selection: $in.selection, thermostat: $in.selection.thermostat }"
    ],
    "data": [
      {
        "input": {
          "selection": {
            "selectionType": "thermostats",
            "selectionMatch": 123456789,
            "thermostat": {
              "settings": {
                "humidity": 45
              }
            }
          }
        },
        "output": {
          "selection": {
            "selectionType": "thermostats",
            "selectionMatch": 123456789
          },
          "thermostat": {
            "settings": {
              "humidity": 45
            }
          }
        }
      }
    ],
    "identifier": 71162423
  },
  {
    "context": [
      "So I need to transform profile key from array to json object. This is the desired output:",
      "Use `with_entries` which lets you convert the array into an object if you adjust the `.key`s accordingly.",
      "Or use `reduce` to build the object by iterating through the array.",
      "Or use `map` to convert each array item into an object, then merge them using `add`.",
      "Output is:\n{\n  \"sunarme\": \"foo\",\n  \"id\": \"foo-id\",\n  \"name\": \"Foo bar\",\n  \"profile\": {\n    \"test1\": [\n      \"product1\",\n      \"product2\"\n    ],\n    \"test2\": [\n      \"product3\",\n      \"product4\",\n      \"product5\"\n    ],\n    \"test3\": [\n      \"product6\",\n      \"product7\",\n      \"product8\"\n    ]\n  }\n}"
    ],
    "utterance": "Transform the 'profile' property from an array of objects into an object where each key is the value of 'id' and its value is the corresponding 'products' array.",
    "expressions": [
      ".profile |= with_entries(.key = .value.id | .value |= .products)",
      ".profile |= reduce .[] as $p ({}; .[$p.id] = $p.products)",
      ".profile |= (map({(.id): .products}) | add)"
    ],
    "data": [
      {
        "input": {
          "sunarme": "foo",
          "id": "foo-id",
          "name": "Foo bar",
          "profile": [
            {
              "id": "test1",
              "products": [
                "product1",
                "product2"
              ],
              "description": "test1 description"
            },
            {
              "id": "test2",
              "products": [
                "product3",
                "product4",
                "product5"
              ],
              "description": "test2 description"
            },
            {
              "id": "test3",
              "products": [
                "product6",
                "product7",
                "product8"
              ],
              "description": "test2 description"
            }
          ]
        },
        "output": {
          "sunarme": "foo",
          "id": "foo-id",
          "name": "Foo bar",
          "profile": {
            "test1": [
              "product1",
              "product2"
            ],
            "test2": [
              "product3",
              "product4",
              "product5"
            ],
            "test3": [
              "product6",
              "product7",
              "product8"
            ]
          }
        }
      }
    ],
    "identifier": 71148657
  },
  {
    "context": [
      "I want the same structure, but with only the first element:",
      "I don't know or care what the name of the key is. I just want the first one.",
      "Use `to_entries`, `from_entries` and an index of your choice.",
      "jq '[to_entries[0]] | from_entries'",
      "jq 'to_entries[0:1] | from_entries'",
      "If you don't like the piping from the other solutions, then how about using string interpolation:",
      "jq '{\"\\(keys_unsorted[0])\"}'"
    ],
    "utterance": "Keep only the first key-value pair in an object, regardless of the key name.",
    "expressions": [
      "[to_entries[0]] | from_entries",
      "to_entries[0:1] | from_entries",
      "{\"\\(keys_unsorted[0])\"}"
    ],
    "data": [
      {
        "input": {
          "a": 1,
          "b": 2,
          "c": 3
        },
        "output": {
          "a": 1
        }
      }
    ],
    "identifier": 71163527
  },
  {
    "context": [
      "The following example prints nothing \"\" if `nonstandard-protocol` is true, or `specialCondition` is neither `matched` nor `unmatched`. Otherwise it'll print `MATCHED` or `NOTMATCHED`, depending on the content of `specialCondition`:",
      "jq --raw-output '\n  if .\"nonstandard-protocol\" then \"\"\n  else if .specialCondition == \"matched\" then \"MATCHED\"\n    elif .specialCondition == \"unmatched\" then \"NOTMATCHED\"\n    else \"\" end\n  end\n' myjsonfile.json > protocol_result.txt",
      "Note: Using \"\" will print nothing as expected, but followed by a newline because it had an output (which essentially is an empty line, then). If you don't want that, change \"\" to empty."
    ],
    "utterance": "Output MATCHED if specialCondition is matched and nonstandard-protocol is false, or NOTMATCHED if specialCondition is unmatched and nonstandard-protocol is false; output nothing otherwise.",
    "expressions": [
      "if .\"nonstandard-protocol\" then \"\" else if .specialCondition == \"matched\" then \"MATCHED\" elif .specialCondition == \"unmatched\" then \"NOTMATCHED\" else \"\" end end"
    ],
    "data": [
      {
        "input": {
          "directory": true,
          "condition": "",
          "specialCondition": "",
          "dataFiles": "",
          "nonstandard-protocol": true
        },
        "output": ""
      },
      {
        "input": {
          "directory": true,
          "condition": "",
          "specialCondition": "matched",
          "dataFiles": "",
          "nonstandard-protocol": false
        },
        "output": "MATCHED"
      },
      {
        "input": {
          "directory": true,
          "condition": "",
          "specialCondition": "unmatched",
          "dataFiles": "",
          "nonstandard-protocol": false
        },
        "output": "NOTMATCHED"
      }
    ],
    "identifier": 71157135
  },
  {
    "context": [
      "Find all characters with the same last name as \"Ron\". And no, you don't already know his last name.",
      ".characters | map(select(.First == \"Ron\") | .Last) | .[0] as $ronsLastName | .characters | map(select(.Last == $ronsLastName))",
      "(.characters[] | select(.First == \"Ron\" ).Last) as $last | .characters |= map(select(.Last == $last))",
      "If you want to make the call with a dynamic first name, provide it using a parameter variable:\n\njq --arg first \"Ron\" '(\n  .characters[] | select(.First == $first).Last) as $last\n  | .characters |= map(select(.Last == $last))'"
    ],
    "utterance": "Find all character objects where the last name is the same as the character with first name \"Ron\".",
    "expressions": [
      ".characters | map(select(.First == \"Ron\") | .Last) | .[0] as $ronsLastName | .characters | map(select(.Last == $ronsLastName))",
      "(.characters[] | select(.First == \"Ron\" ).Last) as $last | .characters |= map(select(.Last == $last))",
      "(.characters[] | select(.First == $first).Last) as $last | .characters |= map(select(.Last == $last))"
    ],
    "data": [
      {
        "input": {
          "characters": [
            {
              "First": "Fred",
              "Last": "Weasley"
            },
            {
              "First": "George",
              "Last": "Weasley"
            },
            {
              "First": "Hermione",
              "Last": "Granger"
            },
            {
              "First": "Ron",
              "Last": "Weasley"
            },
            {
              "First": "Hagrid"
            },
            {
              "First": "Draco",
              "Last": "Malfoy"
            },
            {
              "First": "Molly",
              "Last": "Weasley"
            },
            {
              "First": "Voldemort"
            },
            {
              "First": "Lucius",
              "Last": "Malfoy"
            }
          ]
        },
        "output": {
          "characters": [
            {
              "First": "Fred",
              "Last": "Weasley"
            },
            {
              "First": "George",
              "Last": "Weasley"
            },
            {
              "First": "Ron",
              "Last": "Weasley"
            },
            {
              "First": "Molly",
              "Last": "Weasley"
            }
          ]
        }
      }
    ],
    "identifier": 71178902
  },
  {
    "context": [
      "I want to get key-value pair objects based on their CC role. In this example there are 3 roles(Presenter, Approver, Customer). Presenter is of type `TO`. Other 2 are of type `CC`. I want to get of type `CC`. There can be more as it is dynamic.",
      "Use `with_entries` to make changes based on keys and values:",
      "with_entries(\n  (.key / \"_CC_\") as $key | select($key[1])\n  | {key: $key[0], value: {email_address: .value, role: $key[0]}}\n)"
    ],
    "utterance": "Extract all objects where the key contains '_CC_' and output a map of role to an object with email_address and role fields.",
    "expressions": [
      "with_entries((.key / \"_CC_\") as $key | select($key[1]) | {key: $key[0], value: {email_address: .value, role: $key[0]}})"
    ],
    "data": [
      {
        "input": {
          "Presenter_TO_Email": "roney@domain.com",
          "Approver_CC_Email": "tim@domain.com",
          "Customer_CC_Email": "alex@domain.com",
          "Invoice": "001",
          "Date": "2022-02-14"
        },
        "output": {
          "Approver": {
            "email_address": "tim@domain.com",
            "role": "Approver"
          },
          "Customer": {
            "email_address": "alex@domain.com",
            "role": "Customer"
          }
        }
      }
    ],
    "identifier": 71211622
  },
  {
    "context": [
      "As a matter of fact, you can also utilize the behaviour of the [comma](https://stedolan.github.io/jq/manual/v1.6/#Comma%3A%2C) here. Set one context to `{a}`, another one to `{b}`, and evaluate `{a,b}` for both.",
      ".[] | {a:.[]}, {b:.[]} | {a,b}",
      "{\n  \"a\": 3,\n  \"b\": null\n}\n{\n  \"a\": null,\n  \"b\": 3\n}"
    ],
    "utterance": "Produce one object with key a set to 3 and b set to null, and another object with a set to null and b set to 3, given the input [[3]]",
    "expressions": [
      ".[] | {a:.[]}, {b:.[]} | {a,b}"
    ],
    "data": [
      {
        "input": [
          [
            3
          ]
        ],
        "output": [
          {
            "a": 3,
            "b": null
          },
          {
            "a": null,
            "b": 3
          }
        ]
      }
    ],
    "identifier": 71202247
  },
  {
    "context": [
      "I have the following json:\n{\n   \"thermostats\": [\n      {\n         \"name\": \"Thermostat1\",\n         \"identifier\": 111111111111\n      },\n      {\n         \"name\": \"Thermostat2\",\n         \"identifier\": 222222222222\n      }\n   ]\n}",
      "I'd like to add the following `{default: yes}` to the one that I select.",
      "Use `+=` to add the object on the selected entry",
      "(.thermostats[] | select(.identifier == 111111111111)) += {default: \"yes\"}"
    ],
    "utterance": "Add {default: \"yes\"} to the object inside thermostats array where identifier equals 111111111111.",
    "expressions": [
      "(.thermostats[] | select(.identifier == 111111111111)) += {default: \"yes\"}"
    ],
    "data": [
      {
        "input": {
          "thermostats": [
            {
              "name": "Thermostat1",
              "identifier": 111111111111
            },
            {
              "name": "Thermostat2",
              "identifier": 222222222222
            }
          ]
        },
        "output": {
          "thermostats": [
            {
              "name": "Thermostat1",
              "identifier": 111111111111,
              "default": "yes"
            },
            {
              "name": "Thermostat2",
              "identifier": 222222222222
            }
          ]
        }
      }
    ],
    "identifier": 71224676
  },
  {
    "context": [
      "I am attempting to use `jq` to modify this document into something that looks like this:",
      "{\n  \"bbb_0\": \"bla bla bla\",\n  \"ccc_0\": \"lorem ipsum\",\n  \"ccc_1\": \"sample text\",\n  \"ddd_0\": \"foo\",\n  \"eee_0\": \"some text\",\n  \"eee_1\": \"some more text\",\n  \"eee_2\": \"foobar\"\n}",
      "jq '\n  reduce .[] as {$id, $lines} ({};\n    . + ($lines | with_entries(.key |= \"\\($id)_\\(.)\"))\n  )\n'",
      "map(.id as $id | .lines | with_entries(.key |= \"\\($id)_\\(.)\")) | add"
    ],
    "utterance": "Flatten an array of objects with 'id' and 'lines' fields into a single object mapping each 'id_index' to the corresponding string from 'lines'.",
    "expressions": [
      "reduce .[] as {$id, $lines} ({}; . + ($lines | with_entries(.key |= \"\\($id)_\\(.)\")))",
      "map(.id as $id | .lines | with_entries(.key |= \"\\($id)_\\(.)\")) | add"
    ],
    "data": [
      {
        "input": [
          {
            "id": "bbb",
            "lines": [
              "bla bla bla"
            ]
          },
          {
            "id": "ccc",
            "lines": [
              "lorem ipsum",
              "sample text"
            ]
          },
          {
            "id": "ddd",
            "lines": [
              "foo"
            ]
          },
          {
            "id": "eee",
            "lines": [
              "some text",
              "some more text",
              "foobar"
            ]
          }
        ],
        "output": {
          "bbb_0": "bla bla bla",
          "ccc_0": "lorem ipsum",
          "ccc_1": "sample text",
          "ddd_0": "foo",
          "eee_0": "some text",
          "eee_1": "some more text",
          "eee_2": "foobar"
        }
      }
    ],
    "identifier": 71204113
  },
  {
    "context": [
      "From key's color yellow or red, I add id value.",
      "So  I want to get the X dictionary\n\n    X=(\n       ['yellow']=\"9b058640 5ty87a\"\n       ['red']=\"9b058640 0ui9k40\"\n     )",
      "jq -r '\n    reduce .[] as $item ({}; .[$item.color] += [$item.id])\n    | to_entries[]\n    | \"X[\\(.key | @sh)]=\\(.value | join(\" \") | @sh)\"\n  '",
      "jq -r '\"a[\\(.color)]+=${a[\\(.color)]+ }\\(.id)\"' file.json",
      "(\"yellow\", \"red\") as $color \n    | @sh \"[\\($color)]=\\(map(select(.color == $color).id) | join(\" \"))\""
    ],
    "utterance": "Group id values by color (yellow or red) as keys, with each value being a space-separated string of ids matching that color.",
    "expressions": [
      "reduce .[] as $item ({}; .[$item.color] += [$item.id]) | to_entries[] | \"X[\\(.key | @sh)]=\\(.value | join(\" \") | @sh)\"",
      "\"a[\\(.color)]+=${a[\\(.color)]+ }\\(.id)\"",
      "(\"yellow\", \"red\") as $color | @sh \"[\\($color)]=\\(map(select(.color == $color).id) | join(\" \"))\""
    ],
    "data": [
      {
        "input": [
          {
            "id": "9b058640",
            "type": "db",
            "color": "red",
            "host": "db1"
          },
          {
            "id": "0u858640",
            "type": "db",
            "color": "yellow",
            "host": "db2"
          },
          {
            "id": "0ui9k40",
            "type": "net",
            "color": "red",
            "host": "net1"
          },
          {
            "id": "5ty87a",
            "type": "net",
            "color": "yellow",
            "host": "net2"
          }
        ],
        "output": {
          "red": "9b058640 0ui9k40",
          "yellow": "0u858640 5ty87a"
        }
      }
    ],
    "identifier": 71196669
  },
  {
    "context": [
      "def addvalue($f): map(. + $f); addvalue(.[0])",
      "input:",
      "[[1,2],[10,20]]",
      "output:",
      "[",
      "  [",
      "    1,",
      "    2,",
      "    1,",
      "    2",
      "  ],",
      "  [",
      "    10,",
      "    20,",
      "    1,",
      "    2",
      "  ]",
      "]",
      "In your third example, the function's parameter is a variable, and it is called with an argument which is a filter. Therefore, to set the function's parameter variable, the argument filter has to be evaluated immediately. This \"early\" context is the primary input. The overall evaluation is as follows:",
      "[[1,2], [10,20]] | def addvalue($f): map(. + $f); addvalue(.[0])",
      "[[1,2], [10,20]] | def addvalue($f): map(. + $f); addvalue([1,2])",
      "[[1,2], [10,20]] | map(. + [1,2])",
      "[[1,2] + [1,2], [10,20] + [1,2]]",
      "[[1,2,1,2], [10,20,1,2]]"
    ],
    "utterance": "For each array in the input, append the first subarray to each element.",
    "expressions": [
      "def addvalue($f): map(. + $f); addvalue(.[0])"
    ],
    "data": [
      {
        "input": [
          [
            1,
            2
          ],
          [
            10,
            20
          ]
        ],
        "output": [
          [
            1,
            2,
            1,
            2
          ],
          [
            10,
            20,
            1,
            2
          ]
        ]
      }
    ],
    "identifier": 71230251
  },
  {
    "context": [
      "So if the user enters \"Atom Man\", the script should print his secret identity (\"secretIdentity\": \"Dan Smith\") and his powers.",
      "I don't quite understand how I can filter a certain hero from the json file using the HERONAME1 variable and how to include their powers in the output as well.",
      "HERONAME1=$HERONAME1 jq -r '.members[] | select(.name==env.HERONAME1) | {secretIdentity}, {powers}' superhero.json"
    ],
    "utterance": "Retrieve the secret identity and powers of the member whose name matches a given input value such as 'Atom Man'.",
    "expressions": [
      ".members[] | select(.name==env.HERONAME1) | {secretIdentity}, {powers}",
      ".members[] | select(.name==\"Atom Man\") | {secretIdentity}, {powers}"
    ],
    "data": [
      {
        "input": {
          "squadName": "Super hero squad",
          "homeTown": "Metropolia",
          "formed": 2013,
          "secretBase": "Super HQ",
          "active": true,
          "members": [
            {
              "name": "Atom Man",
              "age": 25,
              "secretIdentity": "Dan Smith",
              "powers": [
                "Radiation resistance",
                "Radiation blast"
              ]
            },
            {
              "name": "Super Man",
              "age": 26,
              "secretIdentity": "Clark",
              "powers": [
                "Flying power",
                "Super human strength"
              ]
            },
            {
              "name": "Bat Man",
              "age": 24,
              "secretIdentity": "Bruce",
              "powers": [
                "Pakour",
                "Night vision"
              ]
            }
          ]
        },
        "output": [
          {
            "secretIdentity": "Dan Smith"
          },
          {
            "powers": [
              "Radiation resistance",
              "Radiation blast"
            ]
          }
        ]
      }
    ],
    "identifier": 71237635
  },
  {
    "context": [
      "echo \"$lval\" \"$(sed \"s/$lval//\" file.ts | jq 'del(.accounts[].type.fields[] | select (.name == \"reserved\"))')\"",
      "jq -Rsr '\n  capture(\"(?<ts>export type Pools = )(?<json>.*)\";\"m\")\n  | .json |= (fromjson | (.) | tojson)\n  | .ts + .json\n'"
    ],
    "utterance": "Remove all objects with name equal to \"reserved\" from the fields array inside each type object for every entry in accounts.",
    "expressions": [
      "del(.accounts[].type.fields[] | select (.name == \"reserved\"))"
    ],
    "data": [
      {
        "input": {
          "version": "0.1.0",
          "name": "hydra_liquidity_pools",
          "accounts": [
            {
              "name": "poolState",
              "type": {
                "kind": "struct",
                "fields": [
                  {
                    "foo": "bar"
                  },
                  {
                    "name": "reserved",
                    "type": {
                      "defined": "Reserve"
                    }
                  }
                ]
              }
            }
          ]
        },
        "output": {
          "version": "0.1.0",
          "name": "hydra_liquidity_pools",
          "accounts": [
            {
              "name": "poolState",
              "type": {
                "kind": "struct",
                "fields": [
                  {
                    "foo": "bar"
                  }
                ]
              }
            }
          ]
        }
      }
    ],
    "identifier": 71246584
  },
  {
    "context": [
      "I can do it it with `jq` by converting the input to JSON first, but I can't seem to figure out how to do it with `yq` only.",
      "you would just need [`to_entries`](https://stedolan.github.io/jq/manual/#to_entries%2Cfrom_entries%2Cwith_entries) to access key and value, [string interpolation](https://stedolan.github.io/jq/manual/#Stringinterpolation-%5C%28foo%29) in combination with the `-r` flag to produce the output, and [`@sh`](https://stedolan.github.io/jq/manual/#Formatstringsandescaping) to escape for shell compliance:",
      "yq -r 'to_entries[] | \"export \\(.key)=\\(.value | @sh)\"'",
      "export FOO='somefoo'",
      "export BAR='somebar'",
      "$ echo \"$INPUT\" | yq $'.[] | \"export \" + key + \"='\" + . + \"'\"'",
      "The `@sh` operator has been added in [`yq v4.31.1`][1] (with [my humble contribution][2]). Now you can do it pretty much the same way as in `jq`:",
      "yq '.[] | \"export \" + key + \"=\" + @sh'"
    ],
    "utterance": "Produce lines in the format export KEY='VALUE' for each top-level mapping where KEY and VALUE come from the original input.",
    "expressions": [
      "to_entries[] | \"export \\(.key)=\\(.value | @sh)\"",
      ".[] | \"export \" + key + \"='\" + . + \"'\"",
      ".[] | \"export \" + key + \"=\" + @sh"
    ],
    "data": [
      {
        "input": {
          "FOO": "somefoo",
          "BAR": "somebar"
        },
        "output": [
          "export FOO='somefoo'",
          "export BAR='somebar'"
        ]
      }
    ],
    "identifier": 71248669
  },
  {
    "context": [
      ". * 3 as $times_three | .",
      "input:\n3\noutput:\n9",
      "(. * 3) as $times_three | .",
      "input:\n3\noutput:\n3",
      "So if parenthesis `(.*3)` or `(.*4)` is used when the variable is declared then filter behaves predictably.",
      "But if parenthesis is not used `.*3` or `.*4` then strangely the output is 9 for both.",
      "You might expect \n\n. * 4 as $times_four | .\n\nto be equivalent to\n\n(. * 4 ) as $times_four | .\n\nAnd as you point out, some example even suggest this is the case. However, the first snippet is actually equivalent to the following:\n\n. * ( 4 as $times_four | . )",
      ". * ( 4 as $times_four | . )\n\nAnd since `\u2026 as $x` produces its context[1], that's the same as\n\n. * ( . | . )\n\nor\n\n. * .",
      "Thus, it should actually read\n... | (.*3) as $times_three | [. + $times_three] | ...",
      "If you look closely, the full title of that section\n\n> Variable / Symbolic Binding Operator: `... as $identifier | ...`\n\nalso features a pipe symbol next to it, which indicates that it belongs to the assignment's structure.",
      "That said, let's clarify what happens with your examples by putting explicit parentheses around the assignments:"
    ],
    "utterance": "Assign the result of multiplying the input by 3 to a variable, then output the input.",
    "expressions": [
      "(. * 3) as $times_three | ."
    ],
    "data": [
      {
        "input": 3,
        "output": 3
      }
    ],
    "identifier": 71246837
  },
  {
    "context": [
      "how we can create more than one objects like below from an input file.  something like how we do in for loop.",
      "cat cnames.txt | xargs -n2 jq -n '{\n    \"name\": $ARGS.positional[0],\n    \"type\": \"CNAME\",\n    \"value\": $ARGS.positional[1],\n    \"ttl\": 3600\n}' --args | jq -n --slurpfile records /dev/stdin '\n  {\n    \"extra_vars\": {\n      \"oper_tasks\": [ \"records\" ],\n      \"zone_info\": [\n        {\n          \"zone\": \"example.com\",\n          \"records\": $records\n        }\n      ]\n    }\n  }\n'",
      "which returns:\n\n```\n{\n  \"extra_vars\": {\n    \"oper_tasks\": [\n      \"records\"\n    ],\n    \"zone_info\": [\n      {\n        \"zone\": \"example.com\",\n        \"records\": [\n          {\n            \"name\": \"foo.example.com\",\n            \"type\": \"CNAME\",\n            \"value\": \"google.com\",\n            \"ttl\": 3600\n          },\n          {\n            \"name\": \"bar.example.com\",\n            \"type\": \"CNAME\",\n            \"value\": \"stackoverflow.com\",\n            \"ttl\": 3600\n          }\n        ]\n      }\n    ]\n  }\n}\n```"
    ],
    "utterance": "Generate an object containing a zone_info records array where each record uses name and value pairs from all lines of an input file.",
    "expressions": [
      "cat cnames.txt | xargs -n2 jq -n '{\n    \"name\": $ARGS.positional[0],\n    \"type\": \"CNAME\",\n    \"value\": $ARGS.positional[1],\n    \"ttl\": 3600\n}' --args | jq -n --slurpfile records /dev/stdin '\n  {\n    \"extra_vars\": {\n      \"oper_tasks\": [ \"records\" ],\n      \"zone_info\": [\n        {\n          \"zone\": \"example.com\",\n          \"records\": $records\n        }\n      ]\n    }\n  }\n'"
    ],
    "data": [
      {
        "input": [
          "foo.example.com google.com",
          "bar.example.com stackoverflow.com"
        ],
        "output": {
          "extra_vars": {
            "oper_tasks": [
              "records"
            ],
            "zone_info": [
              {
                "zone": "example.com",
                "records": [
                  {
                    "name": "foo.example.com",
                    "type": "CNAME",
                    "value": "google.com",
                    "ttl": 3600
                  },
                  {
                    "name": "bar.example.com",
                    "type": "CNAME",
                    "value": "stackoverflow.com",
                    "ttl": 3600
                  }
                ]
              }
            ]
          }
        }
      }
    ],
    "identifier": 71253174
  },
  {
    "context": [
      "I just want to return any userReleaseDate that ends with '22'",
      "Use `select` directly on the list of objects, extract and check the release date inside its argument:\r\n\r\n    jq '.versions[] | select(.userReleaseDate | endswith(\"22\"))'",
      "Now, your question asks for the dates that end with `22`, but the title suggests you want the objects. For that, you'd want something a little different. We want to select from the versions, not from the dates.\r\n\r\n```sh\r\njq '.versions[] | select( .userReleaseDate | endswith(\"22\") )'       # As a stream\r\n```\r\n\r\n```sh\r\njq '[ .versions[] | select( .userReleaseDate | endswith(\"22\") ) ]'   # As an array\r\n```\r\n\r\n```sh\r\njq '.versions | map( select( .userReleaseDate | endswith(\"22\") ) )'  # As an array\r\n```"
    ],
    "utterance": "Return all objects from the 'versions' array where the 'userReleaseDate' field ends with '22'.",
    "expressions": [
      ".versions[] | select(.userReleaseDate | endswith(\"22\"))",
      "[.versions[] | select(.userReleaseDate | endswith(\"22\"))]",
      ".versions | map(select(.userReleaseDate | endswith(\"22\")))"
    ],
    "data": [
      {
        "input": {
          "versions": [
            {
              "archived": true,
              "description": "Cod version 3.3/Sprint 8",
              "id": "11500",
              "name": "v 3.3",
              "projectId": 11500,
              "releaseDate": "2016-03-15",
              "released": true,
              "self": "https://xxxxxxx.atlassian.net/rest/api/2/version/11500",
              "startDate": "2016-02-17",
              "userReleaseDate": "14/Mar/16",
              "userStartDate": "16/Feb/16"
            },
            {
              "archived": true,
              "description": "Hot fix",
              "id": "12000",
              "name": "v3.3.1",
              "projectId": 11500,
              "releaseDate": "2016-03-15",
              "released": true,
              "self": "https://xxxxxxx.atlassian.net/rest/api/2/version/12000",
              "startDate": "2016-03-15",
              "userReleaseDate": "14/Mar/16",
              "userStartDate": "14/Mar/16"
            },
            {
              "archived": false,
              "id": "29704",
              "name": "Sync-diff v1.0.0",
              "projectId": 11500,
              "releaseDate": "2022-02-16",
              "released": true,
              "self": "https://xxxxxxx.atlassian.net/rest/api/2/version/29704",
              "startDate": "2022-02-06",
              "userReleaseDate": "15/Feb/22",
              "userStartDate": "05/Feb/22"
            }
          ]
        },
        "output": [
          {
            "archived": false,
            "id": "29704",
            "name": "Sync-diff v1.0.0",
            "projectId": 11500,
            "releaseDate": "2022-02-16",
            "released": true,
            "self": "https://xxxxxxx.atlassian.net/rest/api/2/version/29704",
            "startDate": "2022-02-06",
            "userReleaseDate": "15/Feb/22",
            "userStartDate": "05/Feb/22"
          }
        ]
      }
    ],
    "identifier": 71240290
  },
  {
    "context": [
      "I have 2 files that I would like to join based a common key.",
      "I am trying to join both files by adding information from the second file into the first one using the dvc_ssr key value.",
      "I am expecting something like this:",
      "{...\"dvc_ssr\":\"aa-1111\",\"host\":\"hostId1\"}",
      "The idea is really to do a JOIN like in SQL where \"dvc_ssr\" are identical.",
      "Using all parameters of `JOIN`, you'd do",
      "jq --slurpfile fst first.json --slurpfile snd second.json -nc '\n  JOIN(INDEX($snd[]; .dvc_ssr); $fst[]; .dvc_ssr; add)\n'",
      "jq --slurpfile snd second.json -sc '\n  JOIN(INDEX($snd[]; .dvc_ssr); .dvc_ssr)[] | add\n' first.json"
    ],
    "utterance": "Join two files by the dvc_ssr field and add the host field from the second file to matching objects from the first file.",
    "expressions": [
      "jq --slurpfile fst first.json --slurpfile snd second.json -nc 'JOIN(INDEX($snd[]; .dvc_ssr); $fst[]; .dvc_ssr; add)'",
      "jq --slurpfile snd second.json -sc 'JOIN(INDEX($snd[]; .dvc_ssr); .dvc_ssr)[] | add' first.json"
    ],
    "data": [
      {
        "input": [
          [
            {
              "_time": "2022-02-20T23",
              "csp_name": "1",
              "tool_bf_id": "1234",
              "dvc_ssr": "aa-1111"
            },
            {
              "_time": "2022-02-20T23",
              "csp_name": "2",
              "tool_bf_id": "4567",
              "dvc_ssr": "aa-2222"
            },
            {
              "_time": "2022-02-20T23",
              "csp_name": "3",
              "tool_bf_id": "1357",
              "dvc_ssr": "null"
            },
            {
              "_time": "2022-02-20T23",
              "csp_name": "4",
              "tool_bf_id": "2468",
              "dvc_ssr": "aa-1111"
            },
            {
              "_time": "2022-02-20T23",
              "csp_name": "5",
              "tool_bf_id": "1246",
              "dvc_ssr": "null"
            }
          ],
          [
            {
              "host": "hostId1",
              "dvc_ssr": "aa-1111"
            },
            {
              "host": "hostId2",
              "dvc_ssr": "aa-2222"
            }
          ]
        ],
        "output": [
          {
            "_time": "2022-02-20T23",
            "csp_name": "1",
            "tool_bf_id": "1234",
            "dvc_ssr": "aa-1111",
            "host": "hostId1"
          },
          {
            "_time": "2022-02-20T23",
            "csp_name": "2",
            "tool_bf_id": "4567",
            "dvc_ssr": "aa-2222",
            "host": "hostId2"
          },
          {
            "_time": "2022-02-20T23",
            "csp_name": "3",
            "tool_bf_id": "1357",
            "dvc_ssr": "null"
          },
          {
            "_time": "2022-02-20T23",
            "csp_name": "4",
            "tool_bf_id": "2468",
            "dvc_ssr": "aa-1111",
            "host": "hostId1"
          },
          {
            "_time": "2022-02-20T23",
            "csp_name": "5",
            "tool_bf_id": "1246",
            "dvc_ssr": "null"
          }
        ]
      }
    ],
    "identifier": 71248425
  },
  {
    "context": [
      "I am trying to fetch the IDs which are created in last 15 minutes. But I couldnt get it.",
      "You can check the time within jq, but it handles ISO 8601 dates only without milliseconds. Therefore you have to cut them off for comparison. `now` gives you the current time.",
      "jq '.[] | select(.updated_at | \"\\(.[:-5])Z\" | fromdate + 900 > now).id'",
      "If you want to have a parameter for minutes, try:",
      "jq --argjson min 15 '\n  .[] | select(.updated_at | \"\\(.[:-5])Z\" | fromdate + 60 * $min > now).id\n'"
    ],
    "utterance": "Fetch the ids of elements where updated_at is within the last 15 minutes.",
    "expressions": [
      ".[] | select(.updated_at | \"\\(.[:-5])Z\" | fromdate + 900 > now) | .id",
      "--argjson min 15 '.[] | select(.updated_at | \"\\(.[:-5])Z\" | fromdate + 60 * $min > now) | .id'"
    ],
    "data": [
      {
        "input": [
          {
            "id": 47,
            "iid": 12,
            "project_id": 1,
            "status": "pending",
            "source": "push",
            "ref": "new-pipeline",
            "sha": "ab23456789d",
            "web_url": "https://example.com/project/pipelines/47",
            "created_at": "2022-02-24T11:28:34.085Z",
            "updated_at": "2016-08-24T15:32:35.169Z"
          },
          {
            "id": 48,
            "iid": 13,
            "project_id": 1,
            "status": "pending",
            "source": "web",
            "ref": "new-pipeline",
            "sha": "ab23456789d",
            "web_url": "https://example.com/project/pipelines/48",
            "created_at": "2022-02-23T11:28:34.085Z",
            "updated_at": "2016-08-23T15:32:35.169Z"
          }
        ]
      }
    ],
    "identifier": 71254853
  },
  {
    "context": [
      "Now I want to build the first function and send the **JSON** that I have created by parameters, but I would not know how to do it, can you give me a hand?",
      "I tried this way but it gives error. I have little knowledge of **Debian console commands**:",
      "omv-rpc -u admin 'ShareMgmt' 'set' '{'echo $JSON_STRING'}'",
      "You need to use [Shell Parameter Expansion](https://www.gnu.org/savannah-checkouts/gnu/bash/manual/bash.html#Shell-Parameter-Expansion) to access variables:",
      "omv-rpc -u admin 'ShareMgmt' 'set' \"${JSON_STRING}\""
    ],
    "utterance": "Pass a variable containing structured data as a parameter to a shell command by expanding the variable's value in-place.",
    "expressions": [
      "\"${JSON_STRING}\""
    ],
    "data": [
      {
        "input": {
          "JSON_STRING": "{\"name\":\"120GB\",\"mntentref\":\"71fdbd90-ce16-4726-ad8d-35ba8664b4c6\",\"reldirpath\": \"/\",\"mode\": \"775\",\"comment\": \"\",\"uuid\": \"fa4b1c66-ef79-11e5-87a0-0002b3a176b4\"}"
        },
        "output": "{\"name\":\"120GB\",\"mntentref\":\"71fdbd90-ce16-4726-ad8d-35ba8664b4c6\",\"reldirpath\": \"/\",\"mode\": \"775\",\"comment\": \"\",\"uuid\": \"fa4b1c66-ef79-11e5-87a0-0002b3a176b4\"}"
      }
    ],
    "identifier": 71262439
  },
  {
    "context": [
      "Here what I&#39;ve done so far: `jq -r &#39;.content[] | {seasonTitle, number, name} | join(&quot;|&quot;)&#39; file.json`",
      "I&#39;ve tried to convert number to string without any success `jq -r &#39;.content[] | {seasonTitle, &quot;episodeNumber|tostring&quot;, name} | join(&quot;|&quot;)&#39; file.json`",
      "**Expected Result:**\r\n```\r\nTop Master|236|Last Chance / Season 12\r\nTop Master|235|&#201;pisode 8 / Season 12\r\nTop Master|234|&#201;pisode 7 / Season 12\r\n```",
      ".content[] | [.seasonTitle, (.episodeNumber | tostring), .name] | join(\"|\")",
      ".content[] | {seasonTitle, episodeNumber: (.episodeNumber | tostring), name} | join(\"|\")"
    ],
    "utterance": "Output each item with seasonTitle, episodeNumber, and name fields joined by a pipe character, converting episodeNumber to a string if necessary.",
    "expressions": [
      ".content[] | [.seasonTitle, (.episodeNumber | tostring), .name] | join(\"|\")",
      ".content[] | {seasonTitle, episodeNumber: (.episodeNumber | tostring), name} | join(\"|\")"
    ],
    "data": [
      {
        "input": {
          "page": 0,
          "size": 3,
          "count": 3,
          "content": [
            {
              "name": "Last Chance / Season 12",
              "releaseDate": "2008",
              "duration": 2100,
              "episodeNumber": 236,
              "title": "Last Chance / Season 12",
              "seasonTitle": "Top Master"
            },
            {
              "name": "\u00c9pisode 8 / Season 12",
              "releaseDate": "2008",
              "duration": 7320,
              "episodeNumber": 235,
              "title": "\u00c9pisode 8 / Season 12",
              "seasonTitle": "Top Master"
            },
            {
              "name": "\u00c9pisode 7 / Season 12",
              "releaseDate": "2008",
              "duration": 7200,
              "episodeNumber": 234,
              "title": "\u00c9pisode 7 / Season 12",
              "seasonTitle": "Top Master"
            }
          ]
        },
        "output": [
          "Top Master|236|Last Chance / Season 12",
          "Top Master|235|\u00c9pisode 8 / Season 12",
          "Top Master|234|\u00c9pisode 7 / Season 12"
        ]
      }
    ],
    "identifier": 71258849
  },
  {
    "context": [
      "eval \"$(jq -r '@sh \"GROUP_NAME=\\(.group_name)\"')\"",
      "result=$(az group exists -n $GROUP_NAME)",
      "jq -n --arg exists \"$result\" '{\"exists\":$exists}'"
    ],
    "utterance": "Extract group_name from object and generate a shell assignment GROUP_NAME=<value>",
    "expressions": [
      "@sh \"GROUP_NAME=\\(.group_name)\""
    ],
    "identifier": 71266384
  },
  {
    "context": [
      "How can I get the value of age from the array without for loop?",
      "jq '.[] | select(.Name==\"age\").value'"
    ],
    "utterance": "Retrieve the value associated with the object whose Name property is equal to 'age' from an array of objects.",
    "expressions": [
      ".[] | select(.Name==\"age\").value"
    ],
    "data": [
      {
        "input": [
          {
            "Name": "firstName",
            "value": "name"
          },
          {
            "Name": "lastName",
            "value": "lname"
          },
          {
            "Name": "brithDate",
            "value": "1-1-2000"
          },
          {
            "Name": "age",
            "value": 21
          }
        ],
        "output": 21
      }
    ],
    "identifier": 71290874
  },
  {
    "context": [
      "And the output should look like this:",
      "k8s-cluster-1",
      "MASTER",
      "aa083",
      "NODE",
      "aa084",
      "NODE",
      "aa085",
      "k8s-cluster-2",
      "MASTER",
      "ab093",
      "NODE",
      "ab094",
      "NODE",
      "ab095",
      "jq -r '.cluster_name, (.cluster_hosts[] | .host_type, .host_hostname)'",
      "If instead your input file is supposed to be an array (in which case the top-level commas were correct but the array brackets [] were missing), then simply prepend the filter with .[] |."
    ],
    "utterance": "List each cluster's name, followed by the type and hostname of each host within the cluster, in order.",
    "expressions": [
      ".cluster_name, (.cluster_hosts[] | .host_type, .host_hostname)",
      ".[] | .cluster_name, (.cluster_hosts[] | .host_type, .host_hostname)"
    ],
    "data": [
      {
        "input": [
          {
            "cluster_name": "k8s-cluster-1",
            "cluster_env": "PROD",
            "cluster_hosts": [
              {
                "host_type": "MASTER",
                "host_hostname": "aa083",
                "host_username": "kubeadm",
                "host_kubernetes_version": ""
              },
              {
                "host_type": "NODE",
                "host_hostname": "aa084",
                "host_username": "kubeadm",
                "host_kubernetes_version": ""
              },
              {
                "host_type": "NODE",
                "host_hostname": "aa085",
                "host_username": "kubeadm",
                "host_kubernetes_version": ""
              }
            ]
          },
          {
            "cluster_name": "k8s-cluster-2",
            "cluster_env": "PROD",
            "cluster_hosts": [
              {
                "host_type": "MASTER",
                "host_hostname": "ab093",
                "host_username": "kubeadm",
                "host_kubernetes_version": ""
              },
              {
                "host_type": "NODE",
                "host_hostname": "ab094",
                "host_username": "kubeadm",
                "host_kubernetes_version": ""
              },
              {
                "host_type": "NODE",
                "host_hostname": "ab095",
                "host_username": "kubeadm",
                "host_kubernetes_version": ""
              }
            ]
          }
        ],
        "output": [
          "k8s-cluster-1",
          "MASTER",
          "aa083",
          "NODE",
          "aa084",
          "NODE",
          "aa085",
          "k8s-cluster-2",
          "MASTER",
          "ab093",
          "NODE",
          "ab094",
          "NODE",
          "ab095"
        ]
      }
    ],
    "identifier": 71263176
  },
  {
    "context": [
      "Now I need to merge the records back and join the value from the new added fields (which are around 10)",
      "`jq -n --slurpfile hosts hosts.jsonl '\n   INDEX( $hosts[]; .dvc_ssr ) as $host_lkup |\n\n   inputs |\n   .host =\n      if has(\"dvc_ssr\") then\n         $host_lkup[.dvc_ssr].host\n      elif has(\"id\") then\n         .id / \";\" | map( $host_lkup[.].host ) | join(\";\")\n      else\n         null\n      end\n' records.jsonl`",
      "Output:\n{\n  \"_time\": \"2022-02-20T23\",\n  \"csp_name\": \"1\",\n  \"tool_bf_id\": \"1234\",\n  \"id\": \"aa-1111;aa-2222\",\n  \"host\": \"hostId1;hostId2\"\n}"
    ],
    "utterance": "Join split records by original id and concatenate their host field values using a semicolon.",
    "expressions": [
      "jq -n --slurpfile hosts hosts.jsonl '\n   INDEX( $hosts[]; .dvc_ssr ) as $host_lkup |\n\n   inputs |\n   .host =\n      if has(\"dvc_ssr\") then\n         $host_lkup[.dvc_ssr].host\n      elif has(\"id\") then\n         .id / \";\" | map( $host_lkup[.].host ) | join(\";\")\n      else\n         null\n      end\n' records.jsonl"
    ],
    "data": [
      {
        "input": [
          {
            "_time": "2022-02-20T23",
            "csp_name": "1",
            "tool_bf_id": "1234",
            "id": "aa-1111;aa-2222"
          },
          {
            "_time": "2022-02-20T23",
            "csp_name": "3",
            "tool_bf_id": "1357",
            "dvc_ssr": "null"
          },
          {
            "_time": "2022-02-20T23",
            "csp_name": "4",
            "tool_bf_id": "2468",
            "dvc_ssr": "aa-3333"
          }
        ],
        "output": [
          {
            "_time": "2022-02-20T23",
            "csp_name": "1",
            "tool_bf_id": "1234",
            "id": "aa-1111;aa-2222",
            "host": "hostId1;hostId2"
          },
          {
            "_time": "2022-02-20T23",
            "csp_name": "3",
            "tool_bf_id": "1357",
            "dvc_ssr": "null",
            "host": null
          },
          {
            "_time": "2022-02-20T23",
            "csp_name": "4",
            "tool_bf_id": "2468",
            "dvc_ssr": "aa-3333",
            "host": "hostId3"
          }
        ]
      }
    ],
    "identifier": 71262461
  },
  {
    "context": [
      "I need to get the following values from the schema if the ID value is CVE-2020-0597:",
      "CWE-125",
      "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H",
      "7.5",
      "jq -r '\n  .CVE_Items[] | select(.cve.CVE_data_meta.ID == \"CVE-2020-0597\")\n  | .cve.problemtype.problemtype_data[0].description[0].value, \n    (.impact.baseMetricV3.cvssV3 | .vectorString, .baseScore)\n'"
    ],
    "utterance": "Select the CWE value, CVSS vector string, and base score for the entry with ID equal to CVE-2020-0597.",
    "expressions": [
      ".CVE_Items[] | select(.cve.CVE_data_meta.ID == \"CVE-2020-0597\") | .cve.problemtype.problemtype_data[0].description[0].value, (.impact.baseMetricV3.cvssV3 | .vectorString, .baseScore)"
    ],
    "data": [
      {
        "input": {
          "CVE_Items": [
            {
              "cve": {
                "CVE_data_meta": {
                  "ID": "CVE-2020-0597"
                },
                "problemtype": {
                  "problemtype_data": [
                    {
                      "description": [
                        {
                          "lang": "en",
                          "value": "CWE-125"
                        }
                      ]
                    }
                  ]
                }
              },
              "impact": {
                "baseMetricV3": {
                  "cvssV3": {
                    "vectorString": "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H",
                    "baseScore": 7.5
                  }
                }
              }
            }
          ]
        },
        "output": [
          "CWE-125",
          "CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H",
          7.5
        ]
      }
    ],
    "identifier": 71258591
  },
  {
    "context": [
      "I would like to concatenate all the json files in a specific folder.",
      "Example :",
      "1.json",
      "[{ \"id\": \"1\", \"name\": \"Product 1\" },{ \"id\": \"2\", \"name\": \"Product 2\" },{ \"id\": \"3\", \"name\": \"Product 3\" }]",
      "2.json",
      "[{ \"id\": \"10\", \"name\": \"Product 10\" },{ \"id\": \"11\", \"name\": \"Product 11\" },{ \"id\": \"12\", \"name\": \"Product 12\" }]",
      "output.json",
      "[{ \"id\": \"1\", \"name\": \"Product 1\" },{ \"id\": \"2\", \"name\": \"Product 2\" },{ \"id\": \"3\", \"name\": \"Product 3\" },{ \"id\": \"10\", \"name\": \"Product 10\" },{ \"id\": \"11\", \"name\": \"Product 11\" },{ \"id\": \"12\", \"name\": \"Product 12\" }]",
      "Read in both files through using `inputs` (which works best if you also add the `--null-input` (or `-n`) option):",
      "jq -n '[inputs[]] ' 1.json 2.json"
    ],
    "utterance": "Concatenate all objects from multiple files in a folder into a single array with all elements.",
    "expressions": [
      "jq -n '[inputs[]]' 1.json 2.json"
    ],
    "data": [
      {
        "input": [
          [
            {
              "id": "1",
              "name": "Product 1"
            },
            {
              "id": "2",
              "name": "Product 2"
            },
            {
              "id": "3",
              "name": "Product 3"
            }
          ],
          [
            {
              "id": "10",
              "name": "Product 10"
            },
            {
              "id": "11",
              "name": "Product 11"
            },
            {
              "id": "12",
              "name": "Product 12"
            }
          ]
        ],
        "output": [
          {
            "id": "1",
            "name": "Product 1"
          },
          {
            "id": "2",
            "name": "Product 2"
          },
          {
            "id": "3",
            "name": "Product 3"
          },
          {
            "id": "10",
            "name": "Product 10"
          },
          {
            "id": "11",
            "name": "Product 11"
          },
          {
            "id": "12",
            "name": "Product 12"
          }
        ]
      }
    ],
    "identifier": 71275460
  },
  {
    "context": [
      "I got the following CSV sample \r\n```\r\nkey1,key2,key3,key4,key5\r\nval1,val2,val3,val4,val5\r\n```\r\nLooking for tips how to convert the above structure into the following JSON structure\r\n```\r\n[\r\n{\r\n&quot;event&quot;: &quot;bleep&quot;,\r\n&quot;sourcetype&quot;: &quot;rats&quot;,\r\n&quot;fields&quot;:  {\r\n&quot;key1&quot;:&quot;val1&quot;,\r\n&quot;key2&quot;:&quot;val2&quot;,\r\n&quot;key3&quot;:&quot;val3&quot;,\r\n&quot;key4&quot;:&quot;val4&quot;,\r\n&quot;key5&quot;:&quot;val5&quot;\r\n }\r\n},\r\n{\r\n&quot;event&quot;: &quot;bleep&quot;,\r\n&quot;sourcetype&quot;: &quot;rats&quot;,\r\n&quot;fields&quot;:  {\r\n&quot;key1&quot;:&quot;val1&quot;,\r\n&quot;key2&quot;:&quot;val2&quot;,\r\n&quot;key3&quot;:&quot;val3&quot;,\r\n&quot;key4&quot;:&quot;val4&quot;,\r\n&quot;key5&quot;:&quot;val5&quot;\r\n }\r\n}\r\n]\r\n```\r\nThanks in advance!",
      "Use `-R` to read the input as raw text\r\n~~~sh\r\njq -R '\r\n  (. / \",\") as $keys\r\n  | [ inputs / \",\" | [$keys, .]\r\n    | reduce transpose[] as $i (\r\n        {event: \"bleep\", sourcetype: \"rats\"}; .fields[$i[0]] = $i[1])\r\n      ]\r\n' input.csv\r\n~~~",
      "[Demo](https://jqplay.org/s/ZoAb12V6Fi)"
    ],
    "utterance": "Convert CSV data with headers into an array where each object contains event as \"bleep\", sourcetype as \"rats\", and a fields object mapping each header to its respective value.",
    "expressions": [
      "jq -R '(. / \",\") as $keys | [ inputs / \",\" | [$keys, .] | reduce transpose[] as $i ({event: \"bleep\", sourcetype: \"rats\"}; .fields[$i[0]] = $i[1]) ]' input.csv"
    ],
    "data": [
      {
        "input": "key1,key2,key3,key4,key5\nval1,val2,val3,val4,val5\nval1,val2,val3,val4,val5\n",
        "output": [
          {
            "event": "bleep",
            "sourcetype": "rats",
            "fields": {
              "key1": "val1",
              "key2": "val2",
              "key3": "val3",
              "key4": "val4",
              "key5": "val5"
            }
          },
          {
            "event": "bleep",
            "sourcetype": "rats",
            "fields": {
              "key1": "val1",
              "key2": "val2",
              "key3": "val3",
              "key4": "val4",
              "key5": "val5"
            }
          }
        ]
      }
    ],
    "identifier": 71265522
  },
  {
    "context": [
      "If you need all in one line, use the `-c` option as before:",
      "jq -c '.data_to_be_encoded |= @base64'",
      "{... \"data_to_be_encoded\": \"W3sibWV0YWRhdGEiOnsicHJvamVjdCI6WyJzb21lUHJvamVjdDEiLCJzb21lUHJvamVjdDIiXSwidGFibGVfbmFtZSI6WyJzb21lVGFibGUxIiwic29tZVRhYmxlMiJdLCJzeXNfaW5zZXJ0ZGF0ZXRpbWUiOiJzb21lRGF0ZSIsInN5c19zb3VyY2VzeXN0ZW0iOiJzb21lU291cmNlU3lzdGVtIn0sImRhdGEiOnsiZmllbGQxIjo2MzUzMzcxMiwiZmllbGQyIjoiIiwiZmllbGQzIjoiaGVsbG8iLCJmaWVsZDQiOiJvdGhlciIsImZpZWxkNSI6MjAyMiwiZmllbGQ2IjoiMCIsImZpZWxkNyI6IjAiLCJmaWVsZDgiOiIwIiwiZmllbGQ5IjoiMCIsImZpZWxkMTAiOiIwIiwiZmllbGQxMSI6IjAifX0seyJtZXRhZGF0YSI6eyJwcm9qZWN0IjpbInNvbWVQcm9qZWN0MSIsInNvbWVQcm9qZWN0MiJdLCJ0YWJsZV9uYW1lIjpbInNvbWVUYWJsZTEiLCJzb21lVGFibGUyIl0sInN5c19pbnNlcnRkYXRldGltZSI6InNvbWVEYXRlIiwic3lzX3NvdXJjZXN5c3RlbSI6InNvbWVTb3VyY2VTeXN0ZW0ifSwiZGF0YSI6eyJmaWVsZDEiOjYzNTMzNzEzLCJmaWVsZDIiOiJZMkpqTFRJd01qSXRkekExTFhSeVppMXZabVp5WlhNdGNtVnVabTl5ZEMxamFHVnhkV2xsY2kxM01EVT0iLCJmaWVsZDMiOiJBMEFWQiIsImZpZWxkNCI6Im90aGVyIiwiZmllbGQ1IjoiSEpsYm1admNuUWdZMmhsY1hWcFpYSWdWekExIiwiZmllbGQ2IjoiIiwiZmllbGQ3IjoiMDIvMDIvMjAyMiIsImZpZWxkOCI6IjE0LzAyLzIwMjIiLCJmaWVsZDkiOiJUaWNrZXQifX1d\"}"
    ],
    "utterance": "Encode the value of the key data_to_be_encoded as base64, leaving all other keys unchanged, and output the result on a single line.",
    "expressions": [
      "jq -c '.data_to_be_encoded |= @base64'"
    ],
    "data": [
      {
        "input": {
          "request_id": 1234,
          "data_to_be_encoded": [
            {
              "metadata": {
                "project": [
                  "someProject1",
                  "someProject2"
                ],
                "table_name": [
                  "someTable1",
                  "someTable2"
                ],
                "sys_insertdatetime": "someDate",
                "sys_sourcesystem": "someSourceSystem"
              },
              "data": {
                "field1": 63533712,
                "field2": "",
                "field3": "hello",
                "field4": "other",
                "field5": 2022,
                "field6": "0",
                "field7": "0",
                "field8": "0",
                "field9": "0",
                "field10": "0",
                "field11": "0"
              }
            },
            {
              "metadata": {
                "project": [
                  "someProject1",
                  "someProject2"
                ],
                "table_name": [
                  "someTable1",
                  "someTable2"
                ],
                "sys_insertdatetime": "someDate",
                "sys_sourcesystem": "someSourceSystem"
              },
              "data": {
                "field1": 63533713,
                "field2": "Y2JjLTIwMjItdzA1LXRyZi1vZmZyZXMtcmVuZm9ydC1jaGVxdWllci13MDU=",
                "field3": "A0AVB",
                "field4": "other",
                "field5": "HJlbmZvcnQgY2hlcXVpZXIgVzA1",
                "field6": "",
                "field7": "02/02/2022",
                "field8": "14/02/2022",
                "field9": "Ticket"
              }
            }
          ]
        },
        "output": {
          "request_id": 1234,
          "data_to_be_encoded": "W3sibWV0YWRhdGEiOnsicHJvamVjdCI6WyJzb21lUHJvamVjdDEiLCJzb21lUHJvamVjdDIiXSwidGFibGVfbmFtZSI6WyJzb21lVGFibGUxIiwic29tZVRhYmxlMiJdLCJzeXNfaW5zZXJ0ZGF0ZXRpbWUiOiJzb21lRGF0ZSIsInN5c19zb3VyY2VzeXN0ZW0iOiJzb21lU291cmNlU3lzdGVtIn0sImRhdGEiOnsiZmllbGQxIjo2MzUzMzcxMiwiZmllbGQyIjoiIiwiZmllbGQzIjoiaGVsbG8iLCJmaWVsZDQiOiJvdGhlciIsImZpZWxkNSI6MjAyMiwiZmllbGQ2IjoiMCIsImZpZWxkNyI6IjAiLCJmaWVsZDgiOiIwIiwiZmllbGQ5IjoiMCIsImZpZWxkMTAiOiIwIiwiZmllbGQxMSI6IjAifX0seyJtZXRhZGF0YSI6eyJwcm9qZWN0IjpbInNvbWVQcm9qZWN0MSIsInNvbWVQcm9qZWN0MiJdLCJ0YWJsZV9uYW1lIjpbInNvbWVUYWJsZTEiLCJzb21lVGFibGUyIl0sInN5c19pbnNlcnRkYXRldGltZSI6InNvbWVEYXRlIiwic3lzX3NvdXJjZXN5c3RlbSI6InNvbWVTb3VyY2VTeXN0ZW0ifSwiZGF0YSI6eyJmaWVsZDEiOjYzNTMzNzEzLCJmaWVsZDIiOiJZMkpqTFRJd01qSXRkekExTFhSeVppMXZabVp5WlhNdGNtVnVabTl5ZEMxamFHVnhkV2xsY2kxM01EVT0iLCJmaWVsZDMiOiJBMEFWQiIsImZpZWxkNCI6Im90aGVyIiwiZmllbGQ1IjoiSEpsYm1admNuUWdZMmhsY1hWcFpYSWdWekExIiwiZmllbGQ2IjoiIiwiZmllbGQ3IjoiMDIvMDIvMjAyMiIsImZpZWxkOCI6IjE0LzAyLzIwMjIiLCJmaWVsZDkiOiJUaWNrZXQifX1d"
        }
      }
    ],
    "identifier": 71128689
  },
  {
    "context": [
      "I want to get \"status\" and \"end_time\" of the newest run. Unfortunately the order is not fix. Meaning the newest run can be first in the list, but also last or in the middle...",
      "jq '\n  [.nodes[].run_data]\n  | max_by(.end_time)\n      # or: sort_by(.end_time) | last\n      # or: sort_by(.end_time)[-1]\n  | {status, end_time}\n' test.json",
      "Here I have converted `end_time` to seconds since Unix epoch and outputted the object with largest seconds value (this is the newest).\n\n[\n[. | map(.end_time | strptime(\"%Y-%m-%dT%H:%M:%SZ\") | mktime), [.[0], .[1]]] \n| transpose[] \n| .[1] += {secs: .[0]} | .[1]\n] \n| sort_by(.secs) | last \n| {status, end_time}"
    ],
    "utterance": "Return the status and end_time of the run_data entry with the latest end_time, regardless of order.",
    "expressions": [
      "[.nodes[].run_data] | max_by(.end_time) | {status, end_time}",
      "[.nodes[].run_data] | sort_by(.end_time) | last | {status, end_time}",
      "[.nodes[].run_data] | sort_by(.end_time)[-1] | {status, end_time}",
      "[.nodes[].run_data | map(.end_time | strptime(\"%Y-%m-%dT%H:%M:%SZ\") | mktime) as $times | . as $data | transpose | map({secs: .[0], data: .[1]}) | sort_by(.secs) | last | .data | {status, end_time}]"
    ],
    "data": [
      {
        "input": {
          "nodes": [
            {
              "run_data": {
                "id": "1234",
                "status": "PASSED",
                "penultimate_status": "PASSED",
                "end_time": "2022-02-28T09:50:05Z"
              }
            },
            {
              "run_data": {
                "id": "4321",
                "status": "PASSED",
                "penultimate_status": "UNKNOWN",
                "end_time": "2020-10-14T13:52:57Z"
              }
            }
          ]
        },
        "output": {
          "status": "PASSED",
          "end_time": "2022-02-28T09:50:05Z"
        }
      }
    ],
    "identifier": 71293398
  },
  {
    "context": [
      "I want to print key value pairs of where the key matches to state and options and also the time and its value.",
      "But my desired output is:",
      "\"time:2022-02-28T22:00:55.196Z\"",
      "  \"key:state\",",
      "  \"value:pending\",",
      "  \"key:options\",",
      "  \"value:request\"",
      "One solution to the stated problem would be:",
      "[.params[] | select(.key|IN(\"state\",\"options\"))",
      "You can use @csv (comma separated values).",
      "[map(select(.key==\"state\" or .key==\"options\"))[] | \"key:\\(.key)\", \"value:\\(.value)\"]"
    ],
    "utterance": "Extract the time and the key/value pairs from params where key is either state or options.",
    "expressions": [
      "\"time:\\(.time)\", [.params[] | select(.key|IN(\"state\",\"options\")) | \"key:\\(.key)\",\"value:\\(.value)\"]",
      "\"time:\\(.time)\", (.params | [map(select(.key==\"state\" or .key==\"options\"))[] | \"key:\\(.key)\", \"value:\\(.value)\"] | @csv)"
    ],
    "data": [
      {
        "input": {
          "time": "2022-02-28T22:00:55.196Z",
          "severity": "INFO",
          "params": [
            {
              "key": "state",
              "value": "pending"
            },
            {
              "key": "options",
              "value": "request"
            },
            {
              "key": "description",
              "value": "[FILTERED]"
            }
          ],
          "content_length": "231"
        },
        "output": [
          "time:2022-02-28T22:00:55.196Z",
          "\"key:state\"",
          "\"value:pending\"",
          "\"key:options\"",
          "\"value:request\""
        ]
      }
    ],
    "identifier": 71301932
  },
  {
    "context": [
      "My goal is to shrink all arrays down to length 3.",
      "(.. | arrays) |= .[:3]",
      "walk(if type == \"array\" then .[:3] else . end)"
    ],
    "utterance": "Truncate every array in the data to a maximum length of 3 elements, no matter where it appears.",
    "expressions": [
      "(.. | arrays) |= .[:3]",
      "walk(if type == \"array\" then .[:3] else . end)"
    ],
    "data": [
      {
        "input": [
          "a",
          "b",
          "c",
          "d",
          "e"
        ],
        "output": [
          "a",
          "b",
          "c"
        ]
      }
    ],
    "identifier": 71322737
  },
  {
    "context": [
      "I want to add to each object in the \"alarms\" key's array the following key:\n{\n   \"bindType\": \"Tag\",\n   \"value\": \"[.]<parent.name>.Name\"\n}\nwhere <parent.name> is \"Test Alarm\" in this example which is the parent-of-the-alarm-array-item's \"name\" key.",
      "I actually don't care about the `setpointA` key, I just want to add the `label` key (as well as another `displayPath` key) to each item in all `alarms` arrays.",
      ".tags[] |= (.name as $name | .alarms[] += (\n  {bindType: \"Tag\", value: \"[.]\\($name).\"} | {\n          label: (.value += \"Name\"),\n    displayPath: (.value += \"Documentation\")\n  }\n))",
      "You cannot reference to parent, you have to save the reference in a variable beforehand, and descend with having access to that variable."
    ],
    "utterance": "Add a label key with value \"[.]<parent.name>.Name\" and a displayPath key with value \"[.]<parent.name>.Documentation\" to each object in all alarms arrays, using the containing object's name.",
    "expressions": [
      ".name as $name | .alarms[] |= (. + { label: { bindType: \"Tag\", value: \"[.]\\($name).Name\" }, displayPath: \"[.]\\($name).Documentation\" })",
      ".tags[] |= (.name as $name | .alarms[] += ({bindType: \"Tag\", value: \"[.]\\($name).\"} | { label: (.value += \"Name\"), displayPath: (.value += \"Documentation\") }))"
    ],
    "data": [
      {
        "input": {
          "valueSource": "memory",
          "dataType": "Boolean",
          "alarms": [
            {
              "setpointA": 1.0,
              "name": "Alarm",
              "priority": "Diagnostic",
              "ackMode": "Auto"
            }
          ],
          "name": "Test Alarm",
          "value": false,
          "tagType": "AtomicTag"
        },
        "output": {
          "valueSource": "memory",
          "dataType": "Boolean",
          "alarms": [
            {
              "setpointA": 1.0,
              "name": "Alarm",
              "priority": "Diagnostic",
              "ackMode": "Auto",
              "label": {
                "bindType": "Tag",
                "value": "[.]Test Alarm.Name"
              },
              "displayPath": "[.]Test Alarm.Documentation"
            }
          ],
          "name": "Test Alarm",
          "value": false,
          "tagType": "AtomicTag"
        }
      }
    ],
    "identifier": 71308155
  },
  {
    "context": [
      "I want to extract these fields with a condition that the `type` key should have the value `dissertation` only.",
      "select(.type == \"dissertation\")\n| [.doi,.title, .publication_year, .publication_date, .type]\n| @csv"
    ],
    "utterance": "Extract the fields doi, title, publication_year, publication_date, and type only for objects where the type key equals \"dissertation\".",
    "expressions": [
      "select(.type == \"dissertation\") | [.doi,.title, .publication_year, .publication_date, .type] | @csv"
    ],
    "data": [
      {
        "input": {
          "id": "https://openalex.org/W2777209504",
          "doi": "https://doi.org/10.24026/1818-1384.1(42).2013.77470",
          "display_name": "Hyperandrogenism as a factor of reproductive losses",
          "title": "Hyperandrogenism as a factor of reproductive losses",
          "publication_year": 2013,
          "publication_date": "2013-03-27",
          "ids": {
            "openalex": "https://openalex.org/W2777209504",
            "doi": "https://doi.org/10.24026/1818-1384.1(42).2013.77470",
            "mag": 2777209504
          },
          "type": "journal-article",
          "counts_by_year": [
            {
              "year": 2019,
              "cited_by_count": 1
            }
          ],
          "cited_by_api_url": "https://api.openalex.org/works?filter=cites:W2777209504",
          "updated_date": "2021-11-03",
          "created_date": "2018-01-05",
          "abstract_inverted_index": {}
        },
        "output": null
      }
    ],
    "identifier": 71318030
  },
  {
    "context": [
      "I have an array of objects with 2 properties, say \"key\" and \"value\":\n[\n   {key: 1, value: a}, \n   {key: 2, value: b}, \n   {key: 1, value: c}\n]",
      "Now, I would like to merge the values of the \"value\" properties of objects with the same \"key\" property value. That is the previous array is transformed into:\n[\n   {key: 1, value: [a, c]}, \n   {key: 2, value: [b]}\n]",
      "group_by(.key) | map({key: .[0].key, value: map(.value)})",
      "group_by([\"key\"]) | .[] |= reduce .[] as $in (\n  {value: []}; .key = $in.key | .value += [$in.value]\n)"
    ],
    "utterance": "For each unique key, collect all corresponding value fields into arrays, producing an array of objects where each object has a unique key and an array of its values.",
    "expressions": [
      "group_by(.key) | map({key: .[0].key, value: map(.value)})",
      "group_by(.key) | map({key: .[0].key, value: map(.value)})"
    ],
    "data": [
      {
        "input": [
          {
            "key": 1,
            "value": "a"
          },
          {
            "key": 2,
            "value": "b"
          },
          {
            "key": 1,
            "value": "c"
          }
        ],
        "output": [
          {
            "key": 1,
            "value": [
              "a",
              "c"
            ]
          },
          {
            "key": 2,
            "value": [
              "b"
            ]
          }
        ]
      }
    ],
    "identifier": 71320895
  },
  {
    "context": [
      "i need to find a way to use jq to find if \"Server0001\" exists in one of the hosts",
      "any(.result[]; .host == \"Server0001\")",
      "jq 'any(.result[]; .host == \"Server00001\")'",
      "if jq --arg host \"Server0001\" -e 'any(.result[]; .host == $host)';"
    ],
    "utterance": "Check if an entry with host name equal to \"Server0001\" exists in the data.",
    "expressions": [
      "any(.result[]; .host == \"Server00001\")",
      "any(.result[]; .host == $host)"
    ],
    "data": [
      {
        "input": {
          "jsonrpc": "2.0",
          "result": [
            {
              "hostid": "10084",
              "host": "Zabbix server",
              "interfaces": [
                {
                  "interfaceid": "1",
                  "ip": "127.0.0.1"
                }
              ]
            },
            {
              "hostid": "10336",
              "host": "AUTO",
              "interfaces": [
                {
                  "interfaceid": "4",
                  "ip": "1.2.3.4"
                }
              ]
            },
            {
              "hostid": "10337",
              "host": "AUTOSERVER",
              "interfaces": [
                {
                  "interfaceid": "5",
                  "ip": "4.5.6.7"
                }
              ]
            },
            {
              "hostid": "10348",
              "host": "Server00001",
              "interfaces": [
                {
                  "interfaceid": "16",
                  "ip": "4.5.6.7"
                }
              ]
            }
          ],
          "id": 2
        },
        "output": true
      }
    ],
    "identifier": 71323947
  },
  {
    "context": [
      "for i in $($JQCOMMAND -c -r '.FilterQueries[].Id' $JSONQUERYFILE) \r\n    do  \r\n        forId=$(echo $i | tr -d '\\r')         #remove weird chars from $i...   \r\n        echo $JQCOMMAND -c -r --arg idToSearch \"$forId\" '.FilterQueries[] | if .Id == $idToSearch then \"YES\" else \"NOPE\" end' $JSONQUERYFILE \r\n        $JQCOMMAND -c -r --arg idToSearch \"$forId\" '.FilterQueries[] | if .Id == $idToSearch then \"YES\" else \"NOPE\" end' $JSONQUERYFILE\r\ndone",
      "$JQCOMMAND -c -r --arg idToSearch \"$forId\" '.FilterQueries[] | if .Id == $idToSearch then \"YES\" else \"NOPE\" end' $JSONQUERYFILE",
      "'.FilterQueries[] | if .Id == $idToSearch then \"YES\" else \"NOPE\" end'"
    ],
    "utterance": "For each Id in FilterQueries, print YES for items whose Id matches the current value and NOPE otherwise.",
    "expressions": [
      ".FilterQueries[] | if .Id == $idToSearch then \"YES\" else \"NOPE\" end"
    ],
    "data": [
      {
        "input": {
          "FilterQueries": [
            {
              "Id": "274301",
              "Value": 1
            },
            {
              "Id": "274005",
              "Value": 2
            },
            {
              "Id": "274004",
              "Value": 3
            },
            {
              "Id": "274000",
              "Value": 4
            }
          ]
        },
        "output": [
          "NOPE",
          "YES",
          "NOPE",
          "NOPE"
        ]
      }
    ],
    "identifier": 71310915
  },
  {
    "context": [
      "jq --arg key \"$rulesTypeKey\" --argjson total \"$totalRules\" \\\n  '.rules.active[$key] = $total'",
      "jq --arg key \"$rulesTypeKey\" --arg total \"$totalRules\" \\\n  '.rules.active[$key] = $total'"
    ],
    "utterance": "Set the value of a key under .rules.active, where the key is provided by a variable, using the corresponding variable value.",
    "expressions": [
      ".rules.active[$key] = $total"
    ],
    "identifier": 71334946
  },
  {
    "context": [
      "I need to change the key for all key value pairs in users to match the value in Columns, like so:",
      "jq -s '\n   ( .[0].Columns[0] | map_values( tostring ) ) as $map |\n   (\n      .[0],\n      (\n         .[1:][] |\n         .Users[] |= with_entries(\n            .key = $map[ .key ]\n         )\n      )\n   )\n'",
      "jq -n '\n   input |\n   ( .Columns[0] | map_values( tostring ) ) as $map |\n   (\n      .,\n      (\n         inputs |\n         .Users[] |= with_entries(\n            .key = $map[ .key ]\n         )\n      )\n   )\n'",
      "input\n| . as $Columns\n| .Columns[0] as $dict\n| input # Users\n| .Users[] |= with_entries(.key |= ($dict[.]|tostring))\n| $Columns, ."
    ],
    "utterance": "Replace all keys in each object of the Users array with the corresponding values from Columns, mapping each attribute name in Users to its respective value from Columns.",
    "expressions": [
      "jq -s ' \n   ( .[0].Columns[0] | map_values( tostring ) ) as $map |\n   (\n      .[0],\n      (\n         .[1:][] |\n         .Users[] |= with_entries(\n            .key = $map[ .key ]\n         )\n      )\n   )\n'",
      "jq -n ' \n   input |\n   ( .Columns[0] | map_values( tostring ) ) as $map |\n   (\n      .,\n      (\n         inputs |\n         .Users[] |= with_entries(\n            .key = $map[ .key ]\n         )\n      )\n   )\n'",
      "input\n| . as $Columns\n| .Columns[0] as $dict\n| input # Users\n| .Users[] |= with_entries(.key |= ($dict[.]|tostring))\n| $Columns, ."
    ],
    "data": [
      {
        "input": {
          "Columns": [
            {
              "email": 123,
              "name": 456,
              "firstName": 789,
              "lastName": 450,
              "admin": 900,
              "licensedSheetCreator": 617,
              "groupAdmin": 354,
              "resourceViewer": 804,
              "id": 730,
              "status": 523,
              "sheetCount": 298
            }
          ]
        }
      },
      {
        "input": {
          "Users": [
            {
              "email": "abc@def.com",
              "name": "Abc Def",
              "firstName": "Abc",
              "lastName": "Def",
              "admin": false,
              "licensedSheetCreator": true,
              "groupAdmin": false,
              "resourceViewer": true,
              "id": 521,
              "status": "ACTIVE",
              "sheetCount": 0
            },
            {
              "email": "aaa@bbb.com",
              "name": "Aaa Bob",
              "firstName": "Aaa",
              "lastName": "Bob",
              "admin": false,
              "licensedSheetCreator": true,
              "groupAdmin": false,
              "resourceViewer": false,
              "id": 352,
              "status": "ACTIVE",
              "sheetCount": 0
            }
          ]
        },
        "output": [
          {
            "123": "abc@def.com",
            "456": "Abc Def",
            "789": "Abc",
            "450": "Def",
            "900": false,
            "617": true,
            "354": false,
            "804": true,
            "730": 521,
            "523": "ACTIVE",
            "298": 0
          },
          {
            "123": "aaa@bbb.com",
            "456": "Aaa Bob",
            "789": "Aaa",
            "450": "Bob",
            "900": false,
            "617": true,
            "354": false,
            "804": false,
            "730": 352,
            "523": "ACTIVE",
            "298": 0
          }
        ]
      }
    ],
    "identifier": 71317638
  },
  {
    "context": [
      "I also want to add some \"static\" objects (`json` shell variable in the example below) to the generated results.",
      "map(split(\"|\") | {\n  object: .[0],\n  type: .[1]\n}) as $data |\n$data + $extra",
      "jq -nR --argjson extra \"$json\" '[inputs / \"|\" | {object:.[0], type:.[1]}] + $extra' data.txt"
    ],
    "utterance": "Combine parsed lines, each split by '|' into objects with keys 'object' and 'type', with additional static objects defined in a variable.",
    "expressions": [
      "split(\"\\n\") | map(select(length>0)) | map(split(\"|\") | {object: .[0], type: .[1]}) as $data | $data + $extra",
      "[inputs / \"|\" | {object: .[0], type: .[1]}] + $extra",
      "reduce (inputs / \"|\") as [$object, $type] ($extra; . + [{$object, $type}])"
    ],
    "data": [
      {
        "input": "apple|fruit\nTesla|car\nsparrow|bird\n",
        "output": [
          {
            "object": "apple",
            "type": "fruit"
          },
          {
            "object": "Tesla",
            "type": "car"
          },
          {
            "object": "sparrow",
            "type": "bird"
          },
          {
            "object": "love",
            "type": "emotion"
          },
          {
            "object": "Ukraine",
            "type": "country"
          }
        ]
      }
    ],
    "identifier": 71330144
  },
  {
    "context": [
      "jq --argjson totalArg \"$typeRuleTotal\" --arg currentType \"$rulesTypeKey\" '.rules.active[$currentType] = $totalArg ' <<<$RULES_REPORT_INIT_JSON >$FILE_REPORT_RULES",
      "You are sequentially writing to the same file but always using the unaltered input `$RULES_REPORT_INIT_JSON`. This makes you see only the last change.",
      "Instead of writing to the file on each iteration, you could save the changes to the variable and write to the file just once in the end:",
      "for \u2026; do\n  \u2026\n  RULES_REPORT_INIT_JSON=\"$(jq \u2026 <<<$RULES_REPORT_INIT_JSON)\"\n  \u2026\ndone\ncat <<<$RULES_REPORT_INIT_JSON >$FILE_REPORT_RULES"
    ],
    "utterance": "Accumulate multiple updates to an object by setting a property in a loop so that the final output includes all changes rather than only the last.",
    "expressions": [
      ".rules.active[$currentType] = $totalArg"
    ],
    "identifier": 71336755
  },
  {
    "context": [
      "I have an array like such:",
      "and I would like to pass each object as a seperate param to xargs and curl.",
      "jq -j 'map(@json) | join(\"\\u0000\")' http/customer/us/customers.json |",
      "xargs -0 -I % curl -X POST http://localhost:3000/customers -d %",
      "jq -r '.[] | @json' http/customer/us/customers.json |",
      "xargs -I % curl -X POST http://localhost:3000/customers -d %",
      "\"\\\\0\" doesn't produce a NUL. You want \"\\u0000\" for that."
    ],
    "utterance": "Output each object in the array as a compact one-line string, separated by NUL characters, so each can be processed individually by xargs.",
    "expressions": [
      "map(@json) | join(\"\\u0000\")",
      ".[] | @json"
    ],
    "data": [
      {
        "input": [
          {
            "customer": {
              "id": "61ae22891dbcb5200f4af298",
              "customerId": "C0001346",
              "companyName": "Real Constructions",
              "displayName": "Real Constructions",
              "fullName": "NiyatiU",
              "email": "niyati@curbwaste.com",
              "phone": "(987) 654-3209"
            },
            "address": {
              "streetName": "NY",
              "state": "NY",
              "city": "NY",
              "zipcode": "39092"
            }
          },
          {
            "customer": {
              "id": "61ae29f31dbcb5200f4af2b2",
              "customerId": "C0001347",
              "companyName": "UK Reality",
              "displayName": "UK Reality",
              "fullName": "VatsalShah",
              "email": "vatsal@curbwaste.com",
              "phone": "(766) 688-1348"
            },
            "address": {
              "streetName": "Queens",
              "state": "NY",
              "city": "Queens",
              "zipcode": "11354"
            }
          }
        ],
        "output": [
          "{\"customer\":{\"id\":\"61ae22891dbcb5200f4af298\",\"customerId\":\"C0001346\",\"companyName\":\"Real Constructions\",\"displayName\":\"Real Constructions\",\"fullName\":\"NiyatiU\",\"email\":\"niyati@curbwaste.com\",\"phone\":\"(987) 654-3209\"},\"address\":{\"streetName\":\"NY\",\"state\":\"NY\",\"city\":\"NY\",\"zipcode\":\"39092\"}}",
          "{\"customer\":{\"id\":\"61ae29f31dbcb5200f4af2b2\",\"customerId\":\"C0001347\",\"companyName\":\"UK Reality\",\"displayName\":\"UK Reality\",\"fullName\":\"VatsalShah\",\"email\":\"vatsal@curbwaste.com\",\"phone\":\"(766) 688-1348\"},\"address\":{\"streetName\":\"Queens\",\"state\":\"NY\",\"city\":\"Queens\",\"zipcode\":\"11354\"}}"
        ]
      }
    ],
    "identifier": 71329446
  },
  {
    "context": [
      "The issue when using `jq` is that some output is not `JSON` is there any way to pretty-print JSON from an output stream where sometimes its text and sometimes it's JSON",
      "if each item is on its own line (ie. all JSON parts are self-contained within their own line, then read in linewise as raw text using the `--raw-input` (or `-R`) option, check if you can convert them to JSON using the `fromjson` builtin and the error suppression operator `?`, and if not (using the  alternative operator `//`) output the line as is using the `--raw-output` (or `-r` option):\n\u2026 | jq --raw-input --raw-output 'fromjson? // .'"
    ],
    "utterance": "Stream output containing both plain text and structured objects, formatting any valid objects in a readable form while leaving plain text unaltered.",
    "expressions": [
      "jq --raw-input --raw-output 'fromjson? // .'"
    ],
    "identifier": 71335459
  },
  {
    "context": [
      "How to escape dash in jq call?",
      "cat afile | jq -r .commit-sha1",
      "For such keys, you need to quote the key, but the quotes must *also* be quoted so that they aren&#39;t removed by the shell prior to running `jq`.",
      "jq -r &#39;.&quot;commit-sha1&quot;&#39;",
      "The abbreviated from `.foo` is for \"simple, identifier-like keys\", according to the man page."
    ],
    "utterance": "Extract the value of a top-level key named commit-sha1 that contains a dash in its name.",
    "expressions": [
      ".\"commit-sha1\""
    ],
    "identifier": 71339030
  },
  {
    "context": [
      "I\u2019d love to select objects based on the key in the hash, but I want the original object format back. How can I achieve this?",
      "should be",
      "{\n  \"google.com\": {\n    \"http\": {\n      \"dest_url\": \"http://stackoverflow.com\"\n    },\n    \"https\": {\n      \"dest_url\": \"http://github.com\"\n    }\n  },\n  \"bbb.com\": {\n    \"https\": {\n      \"dest_url\": \"https://microsoft.com\"\n    }\n  }\n}",
      "Use `with_entries(\u2026)`, which is a shortcut to `to_entries | map(\u2026) | from_entries`, which in turn decomposes the object into an array of key/value representations `to_entries`, modifies each item within that array `map`, and converts it back into the original structure `from_entries`.",
      "jq 'with_entries(select(.key == \"google.com\" or .key == \"bbb.com\"))'"
    ],
    "utterance": "Select only the objects whose keys are \"google.com\" or \"bbb.com\" and keep the original structure.",
    "expressions": [
      "with_entries(select(.key == \"google.com\" or .key == \"bbb.com\"))"
    ],
    "data": [
      {
        "input": {
          "google.com": {
            "http": {
              "dest_url": "http://stackoverflow.com"
            },
            "https": {
              "dest_url": "http://github.com"
            }
          },
          "aaa.com": {
            "https": {
              "dest_url": "https://github.com"
            }
          },
          "bbb.com": {
            "https": {
              "dest_url": "https://microsoft.com"
            }
          },
          "ccc.com": {
            "https": {
              "dest_url": "https://.com"
            }
          }
        },
        "output": {
          "google.com": {
            "http": {
              "dest_url": "http://stackoverflow.com"
            },
            "https": {
              "dest_url": "http://github.com"
            }
          },
          "bbb.com": {
            "https": {
              "dest_url": "https://microsoft.com"
            }
          }
        }
      }
    ],
    "identifier": 71337750
  },
  {
    "context": [
      "Given the [json][1], I need to group by key `userName` the object `userClientDetailDTOList` across all sites->buildings->floors and remove any duplicate mac addresses.",
      "[.billingDetailPerSiteDTOList[].billingDetailPerBuildingDTOList[].billingDetailsPerFloorDTOList[].userClientDetailDTOList[] ] | group_by(.userName) | map((.[0]|del(.associatedMacs)) + { associatedMacs: (map(.associatedMacs[]) | unique) })",
      "As for the second question, if you treated the input as an `INDEX` on the IPs, you could mostly reuse the code from earlier (of course, the `unique` part wouldn't be necessary anymore)",
      "[INDEX(\u2026; .associatedMacs[])[]] | group_by(.userName) | map(\u2026)"
    ],
    "utterance": "Group objects by userName from all userClientDetailDTOList entries nested under sites, buildings, and floors, and ensure that each mac address appears for only one user by removing duplicates across users.",
    "expressions": [
      "[INDEX(.billingDetailPerSiteDTOList[].billingDetailPerBuildingDTOList[].billingDetailsPerFloorDTOList[].userClientDetailDTOList[]; .associatedMacs[])[]] | group_by(.userName) | map({userName: (.[0].userName), associatedMacs: [.[].associatedMacs[]]})"
    ],
    "identifier": 71346971
  },
  {
    "context": [
      "I am trying to update an value for a key based on a select filter. The list contains dictionaries with same key names, but different values. Based on value, I am filtering to select a dictionary and then update the sibling key in it.",
      "Command I am running: jq --arg temp  \"f\" '.[] | select( .key1 == \"c\").key2 |= $temp' test.json",
      "The objects are not part of list now.",
      "Expected output:\n[\n    {\n        \"key1\": \"a\",\n        \"key2\": \"b\"\n    },\n    {\n        \"key1\": \"c\",\n        \"key2\": \"f\"\n    },\n    {\n        \"key1\": \"d\",\n        \"key2\": \"e\"\n    }\n]",
      "Use [map()] to keep the original structure:",
      "jq --arg temp  \"f\" 'map(select( .key1 == \"c\").key2 |= $temp)' test.json",
      "You could also just use another pair of parentheses around the left hand side of the update assignment in order to retain the context:",
      "jq --arg temp \"f\" '(.[] | select(.key1 == \"c\").key2) |= $temp' test.json",
      "jq --arg temp \"f\" '(.[] | select(.key1 == \"c\")).key2 |= $temp' test.json"
    ],
    "utterance": "Update the value of key2 to 'f' for the object where key1 is 'c', preserving the array structure.",
    "expressions": [
      "map(select(.key1 == \"c\").key2 |= $temp)",
      "(.[] | select(.key1 == \"c\").key2) |= $temp",
      "(.[] | select(.key1 == \"c\")).key2 |= $temp"
    ],
    "data": [
      {
        "input": [
          {
            "key1": "a",
            "key2": "b"
          },
          {
            "key1": "c",
            "key2": "d"
          },
          {
            "key1": "d",
            "key2": "e"
          }
        ],
        "output": [
          {
            "key1": "a",
            "key2": "b"
          },
          {
            "key1": "c",
            "key2": "f"
          },
          {
            "key1": "d",
            "key2": "e"
          }
        ]
      }
    ],
    "identifier": 71336852
  },
  {
    "context": [
      "Is there a generic mechanism within jq to select arbitrary elements of a JSON file but return the full structural context of those elements?",
      "what I'd like is to get:\n\n    {\n      \"foo\": {\n        \"one\": true,\n        \"two\": false,\n        \"three\": {\n          \"hello\": \"world\"\n        },\n        \"four\": true\n      },\n      \"baz\": true\n    }\n",
      "running with the filter `.foo.three,.bar[1]` would result in:\n\n    {\n      \"foo\": {\n        \"three\": {\n          \"hello\": \"world\"\n        }\n      },\n      \"bar\": [\n        4\n      ]\n    }",
      "def extract(f):\n  reduce (\n    path(f) as $path | tostream\n    | select(length > 1 and (.[0] | index($path) == 0))\n  ) as $set (\n   null;\n   setpath($set[0]; $set[1])\n);",
      "jq 'def extract(f): \u2026; extract(.foo, .baz)'",
      "jq 'def extract(f): \u2026; extract(.foo.three, .bar[1])'",
      "jq 'def extract(f):\n    . as $input |\n    reduce path(f) as $path (\n    null;\n    if ($path | last | type) == \"string\"\n    then setpath($path; $input | getpath($path))\n    else setpath(($path|.[:-1]);\n                 getpath($path|.[:-1]) +\n                [$input | getpath($path)]\n                )\n    end\n    );\nextract(.foo.three, .bar[1])' data.json"
    ],
    "utterance": "Select arbitrary paths using filters and return only those elements, preserving their original structure and hierarchy in the output.",
    "expressions": [
      "def extract(f):\n  reduce (\n    path(f) as $path | tostream\n    | select(length > 1 and (.[0] | index($path) == 0))\n  ) as $set (\n   null;\n   setpath($set[0]; $set[1])\n);",
      "def extract(f):\n    . as $input |\n    reduce path(f) as $path (\n    null;\n    if ($path | last | type) == \"string\"\n    then setpath($path; $input | getpath($path))\n    else setpath(($path|.[:-1]);\n                 getpath($path|.[:-1]) +\n                [$input | getpath($path)]\n                )\n    end\n    );"
    ],
    "data": [
      {
        "input": {
          "foo": {
            "one": true,
            "two": false,
            "three": {
              "hello": "world"
            },
            "four": true
          },
          "bar": [
            1,
            4,
            5
          ],
          "baz": true
        },
        "output": {
          "foo": {
            "one": true,
            "two": false,
            "three": {
              "hello": "world"
            },
            "four": true
          },
          "baz": true
        }
      },
      {
        "input": {
          "foo": {
            "one": true,
            "two": false,
            "three": {
              "hello": "world"
            },
            "four": true
          },
          "bar": [
            1,
            4,
            5
          ],
          "baz": true
        },
        "output": {
          "foo": {
            "three": {
              "hello": "world"
            }
          },
          "bar": [
            null,
            4
          ]
        }
      }
    ],
    "identifier": 71332069
  },
  {
    "context": [
      "I have been practicing with jq play to try to get all the arrays in a list where website is == \"google\" and create another json list from that.",
      "jq: error (at <stdin>:18): Cannot index array with string \"website\"\nexit status 5",
      "Enclose the `select` with a `map`, as you want to apply the filter to each array item individually while retaining the surrounding array structure.",
      "jq '.items | map(select(.website == \"google\"))'"
    ],
    "utterance": "Select all objects from the items array where the website field equals \"google\" and return them as a list.",
    "expressions": [
      ".items | map(select(.website == \"google\"))"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "name": "name1",
              "id": "1",
              "website": "google"
            },
            {
              "name": "name1",
              "id": "1",
              "website": "google"
            },
            {
              "name": "name1",
              "id": "2",
              "website": "jingle"
            }
          ]
        },
        "output": [
          {
            "name": "name1",
            "id": "1",
            "website": "google"
          },
          {
            "name": "name1",
            "id": "1",
            "website": "google"
          }
        ]
      }
    ],
    "identifier": 71350766
  },
  {
    "context": [
      "The output looks something like this..\n\n    {\n    \"Vpcs\": [\n        {\n            \"CidrBlock\": \"10.29.19.64/26\",\n            \"State\": \"available\",\n            \"VpcId\": \"vpc-0ba51bd29c41d41\",\n            \"IsDefault\": false,\n            \"Tags\": [\n                {\n                    \"Key\": \"Name\",\n                    \"Value\": \"CloudEndure-Europe-Development\"\n                }\n            ]\n        }\n    ]}",
      "and the script I am using looks like this..\n\n    .Vpcs[] | [.VpcId, .CidrBlock,   (.Tags[]|select(.Key==\"Name\")|.Value)]",
      "If I run it under Windows it fails like this. \n\n> jq: error: Name/0 is not defined at <top-level>, line 1:\n.Vpcs[] | [.VpcId, .CidrBlock, (.Tags[]|select(.Key==Name)|.Value)]\njq: 1 compile error",
      "The correct jq program is\n\n```jq\n.Vpcs[] | [.VpcId, .CidrBlock, ( .Tags[] | select( .Key == \"Name\" ) | .Value ) ]\n```"
    ],
    "utterance": "Extract the VpcId, CidrBlock, and the Value of the tag where Key equals \"Name\" for each VPC.",
    "expressions": [
      ".Vpcs[] | [.VpcId, .CidrBlock, (.Tags[] | select(.Key == \"Name\") | .Value)]"
    ],
    "data": [
      {
        "input": {
          "Vpcs": [
            {
              "CidrBlock": "10.29.19.64/26",
              "State": "available",
              "VpcId": "vpc-0ba51bd29c41d41",
              "IsDefault": false,
              "Tags": [
                {
                  "Key": "Name",
                  "Value": "CloudEndure-Europe-Development"
                }
              ]
            }
          ]
        },
        "output": [
          "vpc-0ba51bd29c41d41",
          "10.29.19.64/26",
          "CloudEndure-Europe-Development"
        ]
      }
    ],
    "identifier": 71340156
  },
  {
    "context": [
      "In this example http, https should be reused to generate csv ready format `([][]...)`.",
      "Expected",
      "[\n  \"https://google.com\",\n  \"http://aaa.com\"\n]",
      "[\n  \"http://microsoft.com\",\n  \"http://bbb.com\",\n]",
      "[\n  \"https://microsoft.com\",\n  \"http://ccc.com\"\n]",
      "jq 'to_entries[] | .key as $key | .value | to_entries[] | [.key + \"://\" + $key, .value.dest_url]'",
      "[\n  \"https://google.com\",\n  \"http://aaa.com\"\n]",
      "[\n  \"http://microsoft.com\",\n  \"http://bbb.com\"\n]",
      "[\n  \"https://microsoft.com\",\n  \"http://ccc.com\"\n]"
    ],
    "utterance": "For each website and its protocol, output a row where the first element is the protocol and website concatenated (e.g., 'https://google.com'), and the second element is the corresponding destination URL.",
    "expressions": [
      "to_entries[] | .key as $key | .value | to_entries[] | [.key + \"://\" + $key, .value.dest_url]"
    ],
    "data": [
      {
        "input": {
          "google.com": {
            "https": {
              "dest_url": "http://aaa.com"
            }
          },
          "microsoft.com": {
            "http": {
              "dest_url": "http://bbb.com"
            },
            "https": {
              "dest_url": "http://ccc.com"
            }
          }
        },
        "output": [
          [
            "https://google.com",
            "http://aaa.com"
          ],
          [
            "http://microsoft.com",
            "http://bbb.com"
          ],
          [
            "https://microsoft.com",
            "http://ccc.com"
          ]
        ]
      }
    ],
    "identifier": 71352016
  },
  {
    "context": [
      "What I need to do is get data value of the type A. Currently, we have type SOA and A, but I need to only get data from A.",
      "I want a more dynamic way of searching for specific type (in this case \"A\") and then giving the data value.",
      "Use `select` to match your criteria",
      "jq -r '.records[] | select(.type == \"A\").data'",
      "test.com"
    ],
    "utterance": "Get the value of the data field from the object in records where type is \"A\".",
    "expressions": [
      ".records[] | select(.type == \"A\").data"
    ],
    "data": [
      {
        "input": {
          "records": [
            {
              "id": 1,
              "type": "SOA",
              "name": "@",
              "data": "1800",
              "priority": null,
              "port": null,
              "ttl": 1800,
              "weight": null,
              "flags": null,
              "tag": null
            },
            {
              "id": 2,
              "type": "A",
              "name": "@",
              "data": "test.com",
              "priority": null,
              "port": null,
              "ttl": 1800,
              "weight": null,
              "flags": null,
              "tag": null
            }
          ],
          "links": {},
          "meta": {
            "total": 2
          }
        },
        "output": "test.com"
      }
    ],
    "identifier": 71355129
  },
  {
    "context": [
      "I need the result.id and result.name output using jq for the ones having \r\n\r\nauthorization.roles[].name == \"Supervisor\" \r\n",
      "For the below json we expect 1231 id and name AAAA alone as output as that only has Supervisor as role",
      "you can use `select` to narrow down your target objects (here using `any` to check if at least one of the role names matches your string -- thx @ikegami), then output any part of the resulting object(s):",
      "jq '\n  .results[]\n  | select(any(.authorization.roles[]; .name == \"Supervisor\"))\n  | {id, name}\n'",
      "If instead of a JSON output you need raw text, use the `-r` (or `--raw-output`) flag, and provide the fields you are interested in:",
      "jq -r '\n  .results[]\n  | select(any(.authorization.roles[]; .name == \"Supervisor\"))\n  | .id, .name\n'"
    ],
    "utterance": "Return all objects' id and name where at least one role name is Supervisor",
    "expressions": [
      ".results[] | select(any(.authorization.roles[]; .name == \"Supervisor\")) | {id, name}",
      ".results[] | select(any(.authorization.roles[]; .name == \"Supervisor\")) | .id, .name"
    ],
    "data": [
      {
        "input": {
          "results": [
            {
              "id": "1231",
              "name": "AAAA",
              "div": {
                "id": "AAA",
                "name": "DDSAA",
                "selfUri": ""
              },
              "chat": {
                "jabberId": "nn"
              },
              "department": "Shared Services Organization",
              "email": "Test@gmail.com",
              "primaryContactInfo": [
                {
                  "address": "Test@gmail.com",
                  "mediaType": "EMAIL",
                  "type": "PRIMARY"
                }
              ],
              "addresses": [],
              "state": "active",
              "title": "AAA",
              "username": "Test@gmail.com",
              "version": 27,
              "authorization": {
                "roles": [
                  {
                    "id": "01256689-c5ed-43a5-b370-58522402830d",
                    "name": "AA"
                  },
                  {
                    "id": "1e65b009-9f8f-4eef-9844-83944002c095",
                    "name": "BBB"
                  },
                  {
                    "id": "8a19f1ff-40e5-45d2-b758-14550a173323",
                    "name": "CCC"
                  },
                  {
                    "id": "d02250e2-7071-46bf-885b-43edff2d88a6",
                    "name": "Supervisor"
                  }
                ]
              }
            },
            {
              "id": "1255",
              "name": "BBBB",
              "div": {
                "id": "AAA",
                "name": "DDSAA",
                "selfUri": ""
              },
              "chat": {
                "jabberId": "nn"
              },
              "department": "Shared Services Organization",
              "email": "Test@gmail.com",
              "primaryContactInfo": [
                {
                  "address": "Test@gmail.com",
                  "mediaType": "EMAIL",
                  "type": "PRIMARY"
                }
              ],
              "addresses": [],
              "state": "active",
              "title": "AAA",
              "username": "Test@gmail.com",
              "version": 27,
              "authorization": {
                "roles": [
                  {
                    "id": "01256689-c5ed-43a5-b370-58522402830d",
                    "name": "AA"
                  },
                  {
                    "id": "1e65b009-9f8f-4eef-9844-83944002c095",
                    "name": "BBB"
                  },
                  {
                    "id": "8a19f1ff-40e5-45d2-b758-14550a173323",
                    "name": "CCC"
                  },
                  {
                    "id": "d02250e2-7071-46bf-885b-43edff2d88a6",
                    "name": "Tester"
                  }
                ]
              }
            }
          ]
        },
        "output": {
          "id": "1231",
          "name": "AAAA"
        }
      }
    ],
    "identifier": 71312313
  },
  {
    "context": [
      "Suppose I have an array : `[\"1\",\"2\",\"3\"]`. How can I swap the first element `1` with the later one which is `2` ?",
      "That is the end result to be `[\"2\",\"1\",\"3\"]`",
      "how about the `reverse` function applied to the sublist containing the first two elements",
      "jq '.[:2] |= reverse'",
      "def swap(i;j): .[i] as $t | .[i]=.[j]|.[j]=$t; swap(0;1)"
    ],
    "utterance": "Swap the first and second elements of the array [\"1\",\"2\",\"3\"] so the result is [\"2\",\"1\",\"3\"]",
    "expressions": [
      ".[:2] |= reverse",
      "def swap(i;j): .[i] as $t | .[i]=.[j]|.[j]=$t; swap(0;1)"
    ],
    "data": [
      {
        "input": [
          "1",
          "2",
          "3"
        ],
        "output": [
          "2",
          "1",
          "3"
        ]
      }
    ],
    "identifier": 71368074
  },
  {
    "context": [
      "This snippet works until it faces the file that doesn't have the key (`hobby`).",
      "However if the `.hobby` key doesn't exist it fails miserably.",
      "jq: error (at <stdin>:6): null (null) has no keys",
      "I tried to use if block but it seems not correct. How can we do such a thing either\n- return `[]` (empty array)\n- skip jq excution for the current working file with this problem and go to the next",
      "One of many possibilities would be to use `try`:\n```\n.name as $n | .hobby | try to_entries[] | [ $n, .value]\n```\n",
      "$ cat file | jq -c \"{name,hobby:.hobby[]}|[.[]]\""
    ],
    "utterance": "For each object, output [name, hobby item] pairs and ignore objects where the hobby key does not exist.",
    "expressions": [
      ".name as $n | .hobby | try to_entries[] | [ $n, .value]",
      "{name, hobby:.hobby[]} | [ .[] ]"
    ],
    "data": [
      {
        "input": {
          "name": "bob",
          "hobby": [
            "baseball",
            "baseketball"
          ]
        },
        "output": [
          [
            "bob",
            "baseball"
          ],
          [
            "bob",
            "baseketball"
          ]
        ]
      },
      {
        "input": {
          "name": "alice"
        },
        "output": []
      }
    ],
    "identifier": 71358075
  },
  {
    "context": [
      "I want to receive streamed json inputs and reduce them to an array containing the leaf values.",
      "I expect the output: `[null, null, 0, ...]` but I get empty instead.",
      "These filters should do what you want:\r\n~~~sh\r\njq -n 'reduce inputs as $in ([]; if $in | has(1) then . + [$in[1]] else . end)'\r\n~~~",
      "~~~sh\r\njq -n '[inputs | select(has(1))[1]]'\r\n~~~"
    ],
    "utterance": "Collect the second element from each streamed input (if present) into an array.",
    "expressions": [
      "reduce inputs as $in ([]; if $in | has(1) then . + [$in[1]] else . end)",
      "[inputs | select(has(1))[1]]"
    ],
    "data": [
      {
        "input": [
          [
            [
              0,
              0,
              "a"
            ],
            null
          ],
          [
            [
              0,
              0,
              "a"
            ]
          ],
          [
            [
              0,
              1,
              "b"
            ],
            null
          ],
          [
            [
              0,
              1,
              "b"
            ]
          ],
          [
            [
              0,
              1
            ]
          ],
          [
            [
              1
            ],
            0
          ]
        ],
        "output": [
          null,
          null,
          0
        ]
      }
    ],
    "identifier": 71375408
  },
  {
    "context": [
      "Now I'm trying to do something similar with dict, convert a json dict into a bash associative array",
      "jq -cjn --argjson d \"$dict\" '$d|to_entries|map(\"\\(.key)\\n\\(.value|tostring|@sh)\")|.[]+\"\\u0000\"'",
      "declare -A arr=\"($(jq -r 'to_entries[] | @sh \"[\\(.key)]=\\(.value)\"' <<< \"$arr\"))\"",
      "declare -A arr=\"($(jq -r 'to_entries[] | @sh \"[\\(.key)]=\\(.value | @json)\"' <<< \"$arr\"))\""
    ],
    "utterance": "Convert an object so each key-value pair can be imported into a bash associative array, with keys as the associative keys and corresponding values.",
    "expressions": [
      "jq -r 'to_entries[] | @sh \"[\\(.key)]=\\(.value)\"' <<< \"$arr\"",
      "jq -r 'to_entries[] | @sh \"[\\(.key)]=\\(.value | @json)\"' <<< \"$arr\""
    ],
    "data": [
      {
        "input": {
          "a": "aa",
          "l": "bb",
          "c": "ccccc"
        },
        "output": {
          "a": "aa",
          "l": "bb",
          "c": "ccccc"
        }
      },
      {
        "input": {
          "a": "aa",
          "b": {
            "l": "bb",
            "c": "ccccc"
          }
        },
        "output": {
          "a": "\"aa\"",
          "b": "{\"l\":\"bb\",\"c\":\"ccccc\"}"
        }
      }
    ],
    "identifier": 71385680
  },
  {
    "context": [
      "So, I want to take all the valid `Id`s from above, and shove them, randomly, into the sample data I have, that looks like this `($.invoices[].qbId)`:",
      "The question now is (and this is what I don't know) how to randomly choose from this array and update the sample payload:",
      "jq '.QueryResponse.Invoice | map(.Id)' which can be readily consumed by jq.",
      "jq 'map(. + {\n   invoices : .invoices | map(. + {qbId: ??random here })\n   })\n'"
    ],
    "utterance": "Replace each qbId field in the invoices arrays with a randomly selected valid Id from a given list of Ids.",
    "expressions": [
      "jq --argjson ids '[\"9\",\"10\"]' '\n  map(. + {\n    invoices: (.invoices | map(. + {qbId: ($ids | .[ (now*1000000 | floor) % ($ids|length) ] ) }))\n  })\n'"
    ],
    "data": [
      {
        "input": [
          {
            "id": "fb2430c5-5970-46b0-9947-aaa0b9f177bb",
            "invoices": [
              {
                "description": "2022-02-03 - 179",
                "dueDate": "2022-02-03T22:51:10.206Z",
                "id": "6f904b18-71c6-4fec-a016-7452f6a6b1dc",
                "invoiceDate": "2022-02-03T22:51:10.347Z",
                "openBalance": 200,
                "paidAmount": 200,
                "qbId": "1",
                "totalAmount": 212
              }
            ]
          },
          {
            "id": "fa5b77b5-bfd4-4178-ac31-386ec83f530c",
            "invoices": [
              {
                "description": "2022-01-12 - 95",
                "dueDate": "2022-01-12T14:08:26.219Z",
                "id": "05a58be3-4396-4c15-b9c2-ece68cb2b3fb",
                "invoiceDate": "2022-01-12T14:08:26.399Z",
                "openBalance": 7.33,
                "paidAmount": 7.33,
                "qbId": "",
                "totalAmount": 7.33
              },
              {
                "description": "2022-01-12 - 95",
                "dueDate": "2022-01-12T14:08:26.219Z",
                "id": "91f5ecd0-e18d-4029-8745-143323e02007",
                "invoiceDate": "2022-01-12T14:08:26.580Z",
                "openBalance": 53.13,
                "paidAmount": 53.13,
                "qbId": "",
                "totalAmount": 53.13
              }
            ]
          }
        ]
      }
    ],
    "identifier": 71356034
  },
  {
    "context": [
      "I'm trying to write some jq which uses the instanceID retrieved from the state to query the instance details document (with the same instanceID key). I think if I could get the hostname tag added to the state document in the right place, that would be ideal...",
      "Desirable output (if possible):",
      "jq -n --argfile state state.json --argfile instance instance.json -f program.jq",
      "INDEX($instance.Reservations[].Instances[]; .InstanceId)\n| map_values(.Tags|from_entries.Name) as $dict\n| $state\n| .StoppingInstances |= map(. + {Hostname: $dict[.InstanceId]})"
    ],
    "utterance": "Add the corresponding hostname from the Name tag in instance details to each item in the StoppingInstances list by matching InstanceId, producing one output object per instance with a Hostname field added.",
    "expressions": [
      "INDEX($instance.Reservations[].Instances[]; .InstanceId)\n| map_values(.Tags|from_entries.Name) as $dict\n| $state\n| .StoppingInstances |= map(. + {Hostname: $dict[.InstanceId]})",
      "INDEX($instance | .. | objects | select(has(\"Instances\")) | .Instances[]; \n      .InstanceId)\n| map_values(.Tags|from_entries.Name) as $dict\n| $state\n| .StoppingInstances |= map(. + {Hostname: $dict[.InstanceId]})"
    ],
    "data": [
      {
        "input": {
          "state.json": {
            "StoppingInstances": [
              {
                "CurrentState": {
                  "Code": 80,
                  "Name": "stopped"
                },
                "InstanceId": "i-1",
                "PreviousState": {
                  "Code": 80,
                  "Name": "stopped"
                }
              },
              {
                "CurrentState": {
                  "Code": 80,
                  "Name": "stopped"
                },
                "InstanceId": "i-2",
                "PreviousState": {
                  "Code": 80,
                  "Name": "stopped"
                }
              },
              {
                "CurrentState": {
                  "Code": 80,
                  "Name": "stopped"
                },
                "InstanceId": "i-3",
                "PreviousState": {
                  "Code": 80,
                  "Name": "stopped"
                }
              }
            ]
          },
          "instance.json": {
            "Reservations": [
              {
                "Instances": [
                  {
                    "InstanceId": "i-1",
                    "Tags": [
                      {
                        "Value": "hostname1",
                        "Key": "Name"
                      }
                    ],
                    "AmiLaunchIndex": 0
                  }
                ],
                "ReservationId": "r-1",
                "Groups": []
              },
              {
                "Instances": [
                  {
                    "InstanceId": "i-2",
                    "Tags": [
                      {
                        "Value": "hostname2",
                        "Key": "Name"
                      }
                    ],
                    "AmiLaunchIndex": 0
                  }
                ],
                "ReservationId": "r-1",
                "Groups": []
              },
              {
                "Instances": [
                  {
                    "InstanceId": "i-3",
                    "Tags": [
                      {
                        "Value": "hostname3",
                        "Key": "Name"
                      }
                    ],
                    "AmiLaunchIndex": 0
                  }
                ],
                "ReservationId": "r-1",
                "Groups": []
              }
            ]
          }
        },
        "output": {
          "StoppingInstances": [
            {
              "CurrentState": {
                "Code": 80,
                "Name": "stopped"
              },
              "InstanceId": "i-1",
              "Hostname": "hostname1",
              "PreviousState": {
                "Code": 80,
                "Name": "stopped"
              }
            },
            {
              "CurrentState": {
                "Code": 80,
                "Name": "stopped"
              },
              "InstanceId": "i-2",
              "Hostname": "hostname2",
              "PreviousState": {
                "Code": 80,
                "Name": "stopped"
              }
            },
            {
              "CurrentState": {
                "Code": 80,
                "Name": "stopped"
              },
              "InstanceId": "i-3",
              "Hostname": "hostname3",
              "PreviousState": {
                "Code": 80,
                "Name": "stopped"
              }
            }
          ]
        }
      }
    ],
    "identifier": 71367415
  },
  {
    "context": [
      "Given two files `1.json` and `2.json`. They are both arrays of objects. Need to update field `ping_latency` to 1.json from 2.json",
      "Object with mark \"REMOVED\" should not appear in result. Because it is not in 1.json.",
      "Assuming `.domain` is unique to the updating objects in `2.json` (change if this holds true for another key instead; even spannig over multiple keys is possible using an array, e.g. `[.name, .ip_address]`), you could use `JOIN` based on the unique `INDEX` to match corresponding pairs of objects.",
      "Having the first file as input while reading the second file into a variable using `--argfile`:",
      "jq --argfile a 2.json '[JOIN(INDEX($a[]; .domain); .[]; .domain; add)]' 1.json",
      "Or, equivalently, reading in both files into one array using `--slurp`:",
      "jq -s '[JOIN(INDEX(last[]; .domain); first[]; .domain; add)]' 1.json 2.json"
    ],
    "utterance": "Update each object's ping_latency in the first array with the value from the second array where the domain matches, omitting any objects present only in the second array.",
    "expressions": [
      "jq --argfile a 2.json '[JOIN(INDEX($a[]; .domain); .[]; .domain; add)]' 1.json",
      "jq -s '[JOIN(INDEX(last[]; .domain); first[]; .domain; add)]' 1.json 2.json"
    ],
    "data": [
      {
        "input": [
          [
            {
              "domain": "ca944.nordvpn.com",
              "name": "Canada #944",
              "ip_address": "172.83.40.219"
            },
            {
              "domain": "pl128.nordvpn.com",
              "name": "Poland #128",
              "ip_address": "194.99.105.100"
            },
            {
              "domain": "dk151.nordvpn.com",
              "name": "Denmark #151",
              "ip_address": "82.102.20.236"
            },
            {
              "domain": "be148.nordvpn.com",
              "name": "Belgium #148",
              "ip_address": "82.102.19.137",
              "ping_latency": 334
            }
          ],
          [
            {
              "domain": "ca944.nordvpn.com",
              "name": "Canada #944",
              "ip_address": "172.83.40.219",
              "ping_latency": 123
            },
            {
              "domain": "pl27.nordvpn.com",
              "name": "Poland #27",
              "ip_address": "194.99.105.27",
              "ping_latency": "REMOVED"
            },
            {
              "domain": "dk151.nordvpn.com",
              "name": "Denmark #151",
              "ip_address": "82.102.20.236",
              "ping_latency": 13
            },
            {
              "domain": "be148.nordvpn.com",
              "name": "Belgium #148",
              "ip_address": "82.102.19.137",
              "ping_latency": 67
            }
          ]
        ],
        "output": [
          {
            "domain": "ca944.nordvpn.com",
            "name": "Canada #944",
            "ip_address": "172.83.40.219",
            "ping_latency": 123
          },
          {
            "domain": "pl128.nordvpn.com",
            "name": "Poland #128",
            "ip_address": "194.99.105.100"
          },
          {
            "domain": "dk151.nordvpn.com",
            "name": "Denmark #151",
            "ip_address": "82.102.20.236",
            "ping_latency": 13
          },
          {
            "domain": "be148.nordvpn.com",
            "name": "Belgium #148",
            "ip_address": "82.102.19.137",
            "ping_latency": 67
          }
        ]
      }
    ],
    "identifier": 71370136
  }
]