[
  {
    "context": [
      "$ jq --arg b bar . <<< '{ \"foo\": $b }'",
      "parse error: Invalid numeric literal at line 1, column 12",
      "**Expected output:**",
      "{",
      "  \"foo\": \"bar\"",
      "}",
      "I was trying to construct JSON from scratch by passing in my pattern on stdin. Instead, I should have provided the `--null-input` option, and replaced the `.` with the pattern I was attempting to pass in.",
      "Here's the correct invocation:",
      "$ jq --arg b bar --null-input '{ \"foo\": $b }'",
      "{",
      "  \"foo\": \"bar\"",
      "}"
    ],
    "utterance": "Create an object with key \"foo\" and value \"bar\" using variable substitution.",
    "expressions": [
      "jq --arg b bar --null-input '{ \"foo\": $b }'"
    ],
    "data": [
      {
        "input": null,
        "output": {
          "foo": "bar"
        }
      }
    ],
    "identifier": 65721713
  },
  {
    "context": [
      "output of **cli-output-tags** is below:\n[\n    [\n        \"ENV\",\n        \"DEV\"\n    ],\n    [\n        \"Name\",\n        \"Base-AMI\"\n    ],\n    [\n        \"platform\",\n        \"Linux\"\n    ]\n]",
      "How can I convert this output into Map as below using terraform/(jq command), or is there any other way to fetch required values directly from **cli-output-tags** output:\n\n{\nENV  = \"DEV\",\nName = \"Base-AMI\",\nplatform = \"Linux\"\n}",
      "One way would be to use jq as follows (assuming `cli-output-tags` is the name of the file holding the JSON array of arrays):\n\njq -r -f '\"{\", (.[] | \"\\(.[0]) = \\\"\\(.[1])\\\"\"), \"}\"' cli-output-tags"
    ],
    "utterance": "Convert an array of key-value arrays like [[\"ENV\",\"DEV\"],[\"Name\",\"Base-AMI\"],[\"platform\",\"Linux\"]] into a map object where each key maps to its value.",
    "expressions": [
      "map({(.[0]): .[1]}) | add",
      "from_entries(map({key: .[0], value: .[1]}))"
    ],
    "data": [
      {
        "input": [
          [
            "ENV",
            "DEV"
          ],
          [
            "Name",
            "Base-AMI"
          ],
          [
            "platform",
            "Linux"
          ]
        ],
        "output": {
          "ENV": "DEV",
          "Name": "Base-AMI",
          "platform": "Linux"
        }
      }
    ],
    "identifier": 65731296
  },
  {
    "context": [
      "I'm trying to get jq to output the following from the results array",
      "Item1: has a cover made of steel and requires part ID 27 to be 3",
      "Item2: has a cover made of plastic and requires part ID 27 to be 94",
      "I'd need to search for the attribute ID 17",
      "def id2value($id): .. | objects | select(.attribute_id == $id) | .attribute_value;",
      ".result[]\n| \"\\(.name): has a cover made of \\(.parts_list | id2value(17))\""
    ],
    "utterance": "For each item, construct a string with the item name, the material for attribute_id 17, and the value for attribute_id 27 in the format: '<name>: has a cover made of <attribute_value for id 17> and requires part ID 27 to be <attribute_value for id 27>'.",
    "expressions": [
      "def id2value($id): .. | objects | select(.attribute_id == $id) | .attribute_value; .[].result[] | \"\\(.name): has a cover made of \\(.parts_list | id2value(17)) and requires part ID 27 to be \\(.parts_list | id2value(27))\""
    ],
    "data": [
      {
        "input": [
          {
            "count": 2,
            "load_arg": {
              "limit": 100
            },
            "limit": 100,
            "result": [
              {
                "id": 1234,
                "name": "Item1",
                "parts_list": {
                  "subattributes": {
                    "1234": {
                      "chassisid": 111236,
                      "part_attributes": {
                        "subattributes": {
                          "134322": {
                            "attribute_id": 27,
                            "attribute_value": 3
                          }
                        }
                      }
                    },
                    "1235": {
                      "chassisid": 76,
                      "part_attributes": {
                        "subattributes": {
                          "192134": {
                            "attribute_id": 17,
                            "attribute_value": "steel"
                          }
                        }
                      }
                    }
                  }
                }
              },
              {
                "id": 4321,
                "name": "Item2",
                "parts_list": {
                  "subattributes": {
                    "2212": {
                      "chassisid": 93245,
                      "part_attributes": {
                        "subattributes": {
                          "76423": {
                            "attribute_id": 17,
                            "attribute_value": "plastic"
                          }
                        }
                      }
                    },
                    "65": {
                      "chassisid": 2,
                      "part_attributes": {
                        "subattributes": {
                          "1285": {
                            "attribute_id": 27,
                            "attribute_value": 94
                          }
                        }
                      }
                    }
                  }
                }
              }
            ],
            "offset": 0
          }
        ],
        "output": [
          "Item1: has a cover made of steel and requires part ID 27 to be 3",
          "Item2: has a cover made of plastic and requires part ID 27 to be 94"
        ]
      }
    ],
    "identifier": 65735589
  },
  {
    "context": [
      "I would like to transform it to this:\r\n\r\n{\r\n  \"userA\": {\r\n    \"p1\": [\r\n      \"admin\",\r\n      \"user\",\r\n    ],\r\n    \"p2\": [\r\n      \"viewer\"\r\n    ]\r\n  },\r\n  \"userB\": {\r\n    [...]\r\n  }\r\n}",
      "How can I merge list within object ?",
      "reduce .[] as $o ({};\r\n  $o.projects as $projects\r\n  | reduce $o.bindings[] as $b (.;\r\n      $b.role as $role\r\n      | reduce $b.members[] as $member (.;\r\n          .[$member][$projects] += [$role])) )",
      "reduce .[] as $o ({};\r\n  reduce $o.bindings[] as $b (.;\r\n    reduce $b.members[] as $member (.;\r\n      .[$member][$o.projects] += [$b.role])) )",
      "reduce .[] as { $bindings, $projects } ({};\r\n  reduce $bindings[] as { $members, $role } (.;\r\n    reduce $members[] as $member (.;\r\n      .[$member][$projects] += [ $role ]\r\n    )\r\n  )\r\n)"
    ],
    "utterance": "Reshape objects so that for each user, each project lists all their associated roles merged in an array.",
    "expressions": [
      "reduce .[] as $o ({};\n  $o.projects as $projects\n  | reduce $o.bindings[] as $b (.;\n      $b.role as $role\n      | reduce $b.members[] as $member (.;\n          .[$member][$projects] += [$role])) )",
      "reduce .[] as $o ({};\n  reduce $o.bindings[] as $b (.;\n    reduce $b.members[] as $member (.;\n      .[$member][$o.projects] += [$b.role])) )",
      "reduce .[] as { $bindings, $projects } ({};\n  reduce $bindings[] as { $members, $role } (.;\n    reduce $members[] as $member (.;\n      .[$member][$projects] += [ $role ]\n    )\n  )\n)"
    ],
    "data": [
      {
        "input": [
          {
            "bindings": [
              {
                "members": [
                  "userA",
                  "userB"
                ],
                "role": "admin"
              },
              {
                "members": [
                  "userA"
                ],
                "role": "user"
              }
            ],
            "projects": "p1"
          },
          {
            "bindings": [
              {
                "members": [
                  "userB",
                  "userA"
                ],
                "role": "viewer"
              },
              {
                "members": [
                  "userB"
                ],
                "role": "user"
              }
            ],
            "projects": "p2"
          }
        ],
        "output": {
          "userA": {
            "p1": [
              "admin",
              "user"
            ],
            "p2": [
              "viewer"
            ]
          },
          "userB": {
            "p1": [
              "admin"
            ],
            "p2": [
              "viewer",
              "user"
            ]
          }
        }
      }
    ],
    "identifier": 65732445
  },
  {
    "context": [
      "I\u2019m trying to sort the following json reponse to pick the latest version:",
      "Correct sorting should be:",
      "jq -r [.[]]|max_by(.TagVersion|split(\".\") | map(tonumber))",
      "Turn each component into a number, then sort on the array of integers.",
      "jq 'sort_by(.TagVersion|split(\".\")|map(tonumber))'",
      "This one allows you to use full [Semantic Versioning 2.0 ordering][1] including `-pre.release` suffixes.",
      "jq_semver_cmp='                                           \n  def opt(f):\n      . as $in | try f catch $in;\n  def semver_cmp:\n      sub(\"\\\\+.*$\"; \"\")\n    | capture(\"^(?<v>[^-]+)(?:-(?<p>.*))?$\") | [.v, .p // empty]\n    | map(split(\".\") | map(opt(tonumber)))\n    | .[1] |= (. // {});'",
      "jq \"$jq_semver_cmp\"'sort_by(.TagVersion|semver_cmp)'"
    ],
    "utterance": "Sort an array of objects by the TagVersion field to reflect correct version ordering, so that for example 1.0.9 < 1.0.10 < 1.0.11 < 1.0.77 < 1.1.8.",
    "expressions": [
      "sort_by(.TagVersion|split(\".\")|map(tonumber))",
      "jq_semver_cmp='                                           \n  def opt(f):\n      . as $in | try f catch $in;\n  def semver_cmp:\n      sub(\"\\\\+.*$\"; \"\")\n    | capture(\"^(?<v>[^-]+)(?:-(?<p>.*))?$\") | [.v, .p // empty]\n    | map(split(\".\") | map(opt(tonumber)))\n    | .[1] |= (. // {});'; jq \"$jq_semver_cmp\"'sort_by(.TagVersion|semver_cmp)'"
    ],
    "data": [
      {
        "input": [
          {
            "TagVersion": "1.0.11"
          },
          {
            "TagVersion": "1.1.8"
          },
          {
            "TagVersion": "1.0.10"
          },
          {
            "TagVersion": "1.0.9"
          },
          {
            "TagVersion": "1.0.77"
          }
        ],
        "output": [
          {
            "TagVersion": "1.0.9"
          },
          {
            "TagVersion": "1.0.10"
          },
          {
            "TagVersion": "1.0.11"
          },
          {
            "TagVersion": "1.0.77"
          },
          {
            "TagVersion": "1.1.8"
          }
        ]
      },
      {
        "input": [
          {
            "TagVersion": "1.0.11"
          },
          {
            "TagVersion": "1.0.11-alpha.2"
          },
          {
            "TagVersion": "1.0.11-alpha"
          }
        ],
        "output": [
          {
            "TagVersion": "1.0.11-alpha"
          },
          {
            "TagVersion": "1.0.11-alpha.2"
          },
          {
            "TagVersion": "1.0.11"
          }
        ]
      }
    ],
    "identifier": 65728085
  },
  {
    "context": [
      "I need to create from it the following yaml structure:\n\n    name_zones: # this line we create \n      .zone_name: # the value is taken from the response\n        auth_key: XXX # this line we create \n        records: # this line we create\n# iterate over all records\n      - name: .name\n        type: .type\n        priority: .priority # create line if value set|exist\n        content: .content\n        ttl: .ttl # create line if value set|exist",
      "The following produces the output shown below.\n\n< cf_response.json \\\n  jq '{name_zones:\n        {zone_name: .result[0].zone_name,\n         auth_key: \"XXX\",\n          records:\n            [.result[]\n             | {name, type, content, ttl}\n               + if has(\"priority\") \n                 then {priority} \n                 else null end] }} '|\n  python-yq -y .",
      "If you want to pass in the value of `auth_key` as a parameter to jq, you could use the command-line sequence `--arg auth_key XXX`, and then use `$auth_key` in the jq program.",
      "Output\n\nname_zones:\n  zone_name: test.com\n  auth_key: XXX\n  records:\n    - name: test.com\n      type: A\n      content: 111.111.111.111\n      ttl: 1\n    - name: test.com\n      type: TXT\n      content: google-site-verification=content\n      ttl: 1\n    - name: test.com\n      type: MX\n      content: smtp.test.com\n      ttl: 1\n      priority: 0"
    ],
    "utterance": "Produce an object with a top-level key 'name_zones', containing the zone name as a key, then 'auth_key' set to a specific value, and 'records' as an array of per-record objects with 'name', 'type', 'content', 'ttl', and, if set, 'priority'.",
    "expressions": [
      "{name_zones:{zone_name: .result[0].zone_name, auth_key: \"XXX\", records: [.result[] | {name, type, content, ttl} + if has(\"priority\") then {priority} else null end] }}"
    ],
    "data": [
      {
        "input": {
          "result": [
            {
              "zone_name": "test.com",
              "name": "test.com",
              "type": "A",
              "content": "111.111.111.111",
              "ttl": 1
            },
            {
              "zone_name": "test.com",
              "name": "test.com",
              "type": "TXT",
              "content": "google-site-verification=content",
              "ttl": 1
            },
            {
              "zone_name": "test.com",
              "name": "test.com",
              "type": "MX",
              "content": "smtp.test.com",
              "ttl": 1,
              "priority": 0
            }
          ]
        },
        "output": {
          "name_zones": {
            "zone_name": "test.com",
            "auth_key": "XXX",
            "records": [
              {
                "name": "test.com",
                "type": "A",
                "content": "111.111.111.111",
                "ttl": 1
              },
              {
                "name": "test.com",
                "type": "TXT",
                "content": "google-site-verification=content",
                "ttl": 1
              },
              {
                "name": "test.com",
                "type": "MX",
                "content": "smtp.test.com",
                "ttl": 1,
                "priority": 0
              }
            ]
          }
        }
      }
    ],
    "identifier": 65721626
  },
  {
    "context": [
      "I wish to reduce with jq",
      "to\n\n```\napp --> environment\n...\n```",
      "jq -r '.[] | .beans[] | \"\\(.bean) --> \\(.dependencies[])\"' input.json"
    ],
    "utterance": "List each bean and its dependencies in the format 'bean --> dependency' for all beans.",
    "expressions": [
      ".[] | .beans[] | \"\u0000(.bean) --> \u0000(.dependencies[])\""
    ],
    "data": [
      {
        "input": [
          {
            "context": "app:swagger,dev:8080",
            "parent": null,
            "beans": [
              {
                "bean": "app",
                "aliases": [],
                "scope": "singleton",
                "type": "com.example.App",
                "resource": "null",
                "dependencies": [
                  "environment"
                ]
              },
              {
                "bean": "environment",
                "aliases": [],
                "scope": "singleton",
                "type": "com.example.Environment",
                "resource": "null",
                "dependencies": []
              }
            ]
          }
        ],
        "output": [
          "app --> environment"
        ]
      }
    ],
    "identifier": 65745171
  },
  {
    "context": [
      "Is there an expression that treats the single sub-object {\"size\":\"123\"} like an array with one element, or otherwise allow me to treat both cases with the same query?",
      ".[] | if type == \"object\" then .size else map(.size)|max end",
      "jq .[] | (max? // .) | .size"
    ],
    "utterance": "Extract the size value from each top-level object or from the maximum element's size if it is an array of objects.",
    "expressions": [
      ".[] | if type == \"object\" then .size else map(.size)|max end",
      ".[] | (max? // .) | .size"
    ],
    "data": [
      {
        "input": {
          "Obj1": {
            "size": "123"
          },
          "Obj2": [
            {
              "size": "3"
            },
            {
              "size": "5"
            }
          ]
        },
        "output": [
          "123",
          "5"
        ]
      }
    ],
    "identifier": 65755396
  },
  {
    "context": [
      "I want to extract labels for each post and print it in a file in the exact same format. e.g. for `echo ${tags[1]}` I want it to print:\n[\u001b\"DATA SCIENCE\", \"NLP\", \"PYTHON\"\u001b]",
      "Invoke JQ with the **-c** flag so that it prints each array in a single line.\n```\n$ readarray -t tags < <(jq -c '.data.allPost.edges[].node.labels' file)\n$ echo \"${tags[1]}\"\n[\"DATA SCIENCE\",\"NLP\",\"PYTHON\"]\n```"
    ],
    "utterance": "Extract the labels array for each post's edge so that each array is output as a single line string, preserving the array format.",
    "expressions": [
      ".data.allPost.edges[].node.labels",
      "-c .data.allPost.edges[].node.labels"
    ],
    "data": [
      {
        "input": {
          "data": {
            "allPost": {
              "edges": [
                {
                  "node": {
                    "slug": "fp-cheat-sheet",
                    "labels": [
                      "FUNCTIONAL PROGRAMMING",
                      "HASKELL",
                      "SCALA"
                    ]
                  }
                },
                {
                  "node": {
                    "slug": "nlp-101",
                    "labels": [
                      "DATA SCIENCE",
                      "NLP",
                      "PYTHON"
                    ]
                  }
                }
              ]
            }
          }
        },
        "output": [
          "[\"FUNCTIONAL PROGRAMMING\",\"HASKELL\",\"SCALA\"]",
          "[\"DATA SCIENCE\",\"NLP\",\"PYTHON\"]"
        ]
      }
    ],
    "identifier": 65750516
  },
  {
    "context": [
      "If the file contains an attribute \"event\" with a value of \"abcd123\"\nthen: convert the file into valid json and persist it with the same filename over to location \"C:\\Users\\me\\my-folder\\\"\nelse: ignore it",
      "# If the input is a valid stream of JSON objects\nfunction try {\n  jq -e -n 'any( inputs | objects; select( .event == \"abcd123\") | true)' 2> /dev/null > /dev/null\n}",
      "# If the input is a valid JSON array whose elements are to be checked\nfunction try_array {\n  jq -e 'any( .[] | objects; select( .event == \"abcd123\") | true)' 2> /dev/null > /dev/null\n}"
    ],
    "utterance": "Identify files containing at least one object with an attribute event equal to abcd123.",
    "expressions": [
      "jq -e -n 'any( inputs | objects; select( .event == \"abcd123\") | true)'",
      "jq -e 'any( .[] | objects; select( .event == \"abcd123\") | true)'"
    ],
    "data": [
      {
        "input": "{\"name\":\"bob\",\"event\":\"abcd123\"}",
        "output": true
      },
      {
        "input": "{\"name\":\"ann\",\"event\":\"abcd123\"},{\"name\":\"bob\",\"event\":\"8745LLL\"}",
        "output": true
      },
      {
        "input": "{\"name\":\"ann\",\"event\":\"778PPP\"}",
        "output": false
      },
      {
        "input": "{\"name\":\"ann\",\"event\":\"778PPP\"},{\"name\":\"bob\",\"event\":\"8745LLL\"}",
        "output": false
      }
    ],
    "identifier": 65752370
  },
  {
    "context": [
      "I am trying to use jq to just get the assetId and the activeContractsCount from this in a comma separated way.",
      "So my output for this text should be\n\n    8o-api, 6\n    hips-ts, 1",
      "jq -r '.assets[]|[.apis[].assetId, .apis[].activeContractsCount]|@csv'",
      ".assets[].apis[]\n| [.assetId, .activeContractsCount]\n| @csv"
    ],
    "utterance": "Produce a comma separated list with the assetId and activeContractsCount values from each apis entry.",
    "expressions": [
      ".assets[].apis[] | [.assetId, .activeContractsCount] | @csv",
      ".assets[] | [.apis[].assetId, .apis[].activeContractsCount] | @csv"
    ],
    "data": [
      {
        "input": {
          "total": 320,
          "assets": [
            {
              "audit": {
                "created": {
                  "date": "2019-09-30T12:38:01.421Z"
                },
                "updated": {}
              },
              "organizationId": "12345678",
              "id": 211123898,
              "name": "groupId:760c47ad-c9f2958be:assetId:8o-api",
              "exchangeAssetName": "8O API",
              "groupId": "760c47ad-c9f2958be",
              "assetId": "8o-api",
              "apis": [
                {
                  "audit": {
                    "created": {
                      "date": "2019-09-30T12:38:03.139Z"
                    },
                    "updated": {
                      "date": "2020-03-09T21:37:55.745Z"
                    }
                  },
                  "organizationId": "12345678",
                  "id": 15822364,
                  "groupId": "760c47ad-c9f2958be",
                  "assetId": "8o-api",
                  "assetVersion": "1.0.0",
                  "productVersion": "v1",
                  "description": null,
                  "tags": [],
                  "order": 1,
                  "providerId": null,
                  "deprecated": false,
                  "lastActiveDate": "2021-01-15T22:43:33.881Z",
                  "isPublic": false,
                  "stage": "release",
                  "lastActiveDelta": 7,
                  "pinned": false,
                  "activeContractsCount": 6,
                  "autodiscoveryInstanceName": "v1:15822364"
                }
              ],
              "totalApis": 1,
              "autodiscoveryApiName": "groupId:760c47ad-c9f2958be:assetId:8o-api"
            },
            {
              "audit": {
                "created": {
                  "date": "2018-06-22T19:41:35.760Z"
                },
                "updated": {
                  "date": "2018-09-13T06:20:51.151Z"
                }
              },
              "organizationId": "760c47ad-c9f2958be",
              "id": 210914379,
              "name": "hips-ts",
              "exchangeAssetName": "hips-ts",
              "groupId": "760c47ad-c9f2958be",
              "assetId": "hips-ts",
              "apis": [
                {
                  "audit": {
                    "created": {
                      "date": "2018-06-22T19:41:35.759Z"
                    },
                    "updated": {
                      "date": "2020-03-09T21:37:55.745Z"
                    }
                  },
                  "organizationId": "760c47ad-c9f2958be",
                  "id": 15470738,
                  "groupId": "760c47ad-c9f2958be",
                  "assetId": "hips-ts",
                  "assetVersion": "1.0.0",
                  "productVersion": "v1",
                  "description": null,
                  "tags": [],
                  "order": 1,
                  "providerId": null,
                  "deprecated": false,
                  "lastActiveDate": "2021-01-15T22:43:30.004Z",
                  "endpointUri": null,
                  "isPublic": false,
                  "stage": "release",
                  "lastActiveDelta": 11,
                  "pinned": false,
                  "activeContractsCount": 1,
                  "autodiscoveryInstanceName": "1-test"
                }
              ],
              "totalApis": 1,
              "autodiscoveryApiName": "hips-ts"
            }
          ]
        },
        "output": [
          "\"8o-api\",6",
          "\"hips-ts\",1"
        ]
      }
    ],
    "identifier": 65744656
  },
  {
    "context": [
      "I want to find all objects in the list with a particular `name`, e.g. `\"Carol\"`, then get their indices in the list, and then use those indices to get all the objects in the list which have those objects as their parent, based on their `parentIndex`. So, the above should return Dwayne's object.",
      "The above can be solved with:\n```\njq '. as $top \n  | .[] \n  | select(\n      $top[.parentIndex? | values]\n        .name == \"Carol\"\n    )' \n```",
      "Here's a similar solution that only examines the first \"Carol\":\n```\n(map(.name) | index(\"Carol\")) as $ix\n| .[] \n| select( .parentIndex == $ix )\n| .name\n```"
    ],
    "utterance": "Find all objects whose parent has the name \"Carol\".",
    "expressions": [
      ". as $top | .[] | select($top[.parentIndex? | values].name == \"Carol\")",
      "(map(.name) | indices(\"Carol\"))[] as $ix | .[] | select(.parentIndex == $ix)"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Albert"
          },
          {
            "name": "Brian",
            "parentIndex": 0
          },
          {
            "name": "Carol",
            "parentIndex": 0
          },
          {
            "name": "Dwayne",
            "parentIndex": 2
          },
          {
            "name": "Ethel",
            "parentIndex": 3
          },
          {
            "name": "Francis",
            "parentIndex": 3
          }
        ],
        "output": [
          {
            "name": "Dwayne",
            "parentIndex": 2
          }
        ]
      }
    ],
    "identifier": 65746336
  },
  {
    "context": [
      "ID=$(echo $MGS | jq .[$i].id)",
      "az policy assignment list --scope $ID",
      "for id in $(az account management-group list --query [].id -o tsv)",
      "az policy assignment list --scope $id"
    ],
    "utterance": "Extract each element's id from the array to use as a variable.",
    "expressions": [
      ".[$i].id",
      ".[].id"
    ],
    "identifier": 65763809
  },
  {
    "context": [
      "I\u2019d like to take the values from one json file and add them to another file when other values in the dict match.",
      "Using these json files above (from the Zabbix API), I\u2019d like to add the value of `.proxies[].host` (from `proxies.json`) as `.hosts[].proxy_host` (to `hosts.json`).",
      "This would only be when `.hosts[].proxy_hostid` equals `.proxies[].proxyid`",
      "Desired output:",
      "{\n  \"hosts\": [\n    {\n      \"host\": \"hosta.example.com\",\n      \"hostid\": \"101\",\n      \"proxy_hostid\": \"1\",\n      \"proxy_host\": \"proxy1.example.com\"\n    },\n    ...\n  ]\n}",
      "This indeed is easier with the alternative version of your `proxies.json`. All you need is to store proxies in a variable as reference, and retrieve proxy hosts from it while updating hosts.",
      "jq 'input as { $proxies } | .hosts[] |= . + { proxy_host: $proxies[.proxy_hostid].host }' hosts.json proxies.json"
    ],
    "utterance": "For each host, add a new field 'proxy_host' containing the proxy host whose 'proxyid' matches the host's 'proxy_hostid'.",
    "expressions": [
      "jq 'input as { $proxies } | .hosts[] |= . + { proxy_host: $proxies[.proxy_hostid].host }' hosts.json proxies.json"
    ],
    "data": [
      {
        "input": {
          "hosts": [
            {
              "host": "hosta.example.com",
              "hostid": "101",
              "proxy_hostid": "1"
            },
            {
              "host": "hostb.example.com",
              "hostid": "102",
              "proxy_hostid": "1"
            },
            {
              "host": "hostc.example.com",
              "hostid": "103",
              "proxy_hostid": "2"
            }
          ]
        },
        "output": {
          "hosts": [
            {
              "host": "hosta.example.com",
              "hostid": "101",
              "proxy_hostid": "1",
              "proxy_host": "proxy1.example.com"
            },
            {
              "host": "hostb.example.com",
              "hostid": "102",
              "proxy_hostid": "1",
              "proxy_host": "proxy1.example.com"
            },
            {
              "host": "hostc.example.com",
              "hostid": "103",
              "proxy_hostid": "2",
              "proxy_host": "proxy2.example.com"
            }
          ]
        }
      },
      {
        "input": {
          "proxies": {
            "1": {
              "host": "proxy1.example.com",
              "proxyid": "1"
            },
            "2": {
              "host": "proxy2.example.com",
              "proxyid": "2"
            }
          }
        }
      }
    ],
    "identifier": 65762113
  },
  {
    "context": [
      "I would need to grep all companies with identity==true, but save only the domains from the array that matches identity=true to a new file.",
      "Desired output:\r\n\r\n    companytwo.com\r\n    companytwotwo.net",
      "Well, just use `select` like this:",
      "cat data.json | jq -r '.companies[] | select(.identity) | .domains[]' > yourfile.txt"
    ],
    "utterance": "Extract all domains from companies where identity is true.",
    "expressions": [
      ".companies[] | select(.identity) | .domains[]"
    ],
    "data": [
      {
        "input": {
          "companies": [
            {
              "name": "CompanyOne",
              "url": "https://companyone.com",
              "identity": false,
              "domains": [
                "companyone.com"
              ]
            },
            {
              "name": "CompanyTwo",
              "url": "https://companytwotwo.com",
              "identity": true,
              "domains": [
                "companytwo.com",
                "companytwotwo.net"
              ]
            }
          ]
        },
        "output": [
          "companytwo.com",
          "companytwotwo.net"
        ]
      }
    ],
    "identifier": 65783281
  },
  {
    "context": [
      "I need to extract the key:values as srcip and destip (see below)",
      "the original output is :",
      "[\n  0,\n  \"Done\",\n  \"NONE\",\n  [\n    {\n      \"vserver\": \"somevip\",\n      ...\n      \"srcip\": \u201c1.1.1.1\u201d,\n      ...\n      \"destip\": \"2.2.2.2\",\n      ...\n    },\n    {\n      \"vserver\": \"somevip\",\n      ...\n      \"srcip\": \"3.3.3.3\u201d\n      ...\n      \"destip\": \"4.4.4.4\u201d\n      ...\n    },",
      "After fixing some minor problems with the full JSON shown in the Q, the invocation:",
      "jq '.[3][].srcip' input.json",
      "yields:",
      "\"1.1.1.1\"",
      "\"3.3.3.3\""
    ],
    "utterance": "Extract all srcip values from the array located at index 3 of the top-level array.",
    "expressions": [
      ".[3][].srcip",
      ".[3] | .[] | .srcip"
    ],
    "data": [
      {
        "input": [
          0,
          "Done",
          "NONE",
          [
            {
              "vserver": "somevip",
              "type": "1",
              "typestring": "SOURCEIP",
              "srcip": "1.1.1.1",
              "srcipv6": "::/0",
              "destip": "2.2.2.2",
              "destipv6": "::/0",
              "flags": false,
              "destport": 0,
              "vservername": "somevip",
              "timeout": "0",
              "referencecount": "0",
              "persistenceparam": "1.1.1.1"
            },
            {
              "vserver": "somevip",
              "type": "1",
              "typestring": "SOURCEIP",
              "srcip": "3.3.3.3",
              "srcipv6": "::/0",
              "destip": "4.4.4.4",
              "destipv6": "::/0",
              "flags": false,
              "destport": 0,
              "vservername": "somevip",
              "timeout": "0",
              "referencecount": "0",
              "persistenceparam": "1.1.1.1"
            }
          ]
        ],
        "output": [
          "1.1.1.1",
          "3.3.3.3"
        ]
      }
    ],
    "identifier": 65777236
  },
  {
    "context": [
      "I have some piped output in the form of {\"key\": \"value\"} and I need to insert it into an existing json file along the lines of:\n{\n \"existing_key\":\"value\"\n}\nto get:\n{\n \"existing_key\":\"value\",\n \"key\": \"value\"\n}"
    ],
    "utterance": "Combine a piped object {\"key\": \"value\"} with an existing file so both key-value pairs appear at the top level.",
    "expressions": [
      "jq -s '.[0] * .[1]' file.json -"
    ],
    "data": [
      {
        "input": [
          {
            "existing_key": "value"
          },
          {
            "key": "value"
          }
        ],
        "output": {
          "existing_key": "value",
          "key": "value"
        }
      }
    ],
    "identifier": 65815461
  },
  {
    "context": [
      "I am trying to have this formatted like:",
      "> id expirationTime isExpirationDateCalculated",
      "Something that will look like:",
      "3a7d3f23-edd2-4e14-8e5b-473ccb2d225e         2021-02-19T18:30:00.000Z    true",
      "$ jq -r '.data[0] | [.id, (.MoreInfo.localInfo | .expirationTime, .isExpirationDateCalculated)] | @tsv' tmp.json",
      "[.data[0].id, .data[0].MoreInfo.localInfo.expirationTime, .data[0].MoreInfo.localInfo.isExpirationDateCalculated] | @tsv"
    ],
    "utterance": "Output the id, expirationTime, and isExpirationDateCalculated fields as a tab-separated line.",
    "expressions": [
      ".data[0] | [.id, (.MoreInfo.localInfo | .expirationTime, .isExpirationDateCalculated)] | @tsv",
      "[.data[0].id, .data[0].MoreInfo.localInfo.expirationTime, .data[0].MoreInfo.localInfo.isExpirationDateCalculated] | @tsv"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": "3a7d3f23-edd2-4e14-8e5b-473ccb2d225e",
              "MoreInfo": {
                "Info1": [],
                "Info2": [],
                "localInfo": {
                  "id": "6fa2edf0-d034-458d-857e-e86ed14e850f",
                  "isExpirationDateCalculated": false,
                  "expirationTime": "2021-02-19T18:30:00.000Z"
                },
                "replicationInfos": []
              },
              "vmName": "AD"
            }
          ]
        },
        "output": "3a7d3f23-edd2-4e14-8e5b-473ccb2d225e\t2021-02-19T18:30:00.000Z\tfalse"
      }
    ],
    "identifier": 65811824
  },
  {
    "context": [
      "I want to extract the IPs with \"reserved\" as status but without extractig the data for the gateway/network/broadcast IPs :",
      "cat myfile | jq '.ipAddressTab[] | select(.status == \"reserved\") | select(.type != \"network\") | select(.type != \"gateway\") | select(.type != \"broadcast\")'",
      "But where are the commas between each \" IP part \" ?",
      "There is a way to keep them when I parse my file with jq ?",
      "Here are two broad ways to do it.",
      "cat myfile | jq '.ipAddressTab | map(select(.status == \"reserved\") | select(.type != \"network\") | select(.type != \"gateway\") | select(.type != \"broadcast\"))'",
      "cat myfile | jq '.ipAddressTab | [ .[] | select(.status == \"reserved\") | select(.type != \"network\") | select(.type != \"gateway\") | select(.type != \"broadcast\") ]'"
    ],
    "utterance": "Output an array of IP objects where status is \"reserved\" and type is not \"network\", \"gateway\", or \"broadcast\", with commas between objects.",
    "expressions": [
      ".ipAddressTab | map(select(.status == \"reserved\") | select(.type != \"network\") | select(.type != \"gateway\") | select(.type != \"broadcast\"))",
      ".ipAddressTab | [ .[] | select(.status == \"reserved\") | select(.type != \"network\") | select(.type != \"gateway\") | select(.type != \"broadcast\") ]"
    ],
    "data": [
      {
        "input": {
          "cidr": "X.X.X.X/27",
          "defaultGateway": "X.X.X.X",
          "full": false,
          "id": "X.X.X.X",
          "ipAddressTab": [
            {
              "alias_domain": null,
              "alias_name": null,
              "description": "This is the network address for X.X.X.X/27",
              "dnr_rr": null,
              "dns_domain": null,
              "environnement": null,
              "fdqn": null,
              "hostname": null,
              "ip": "X.X.X.X",
              "requester": null,
              "status": "reserved",
              "type": "network"
            },
            {
              "alias_domain": null,
              "alias_name": null,
              "description": "This is the default gateway address for X.X.X.X/27",
              "dnr_rr": null,
              "dns_domain": null,
              "environnement": null,
              "fdqn": null,
              "hostname": null,
              "ip": "X.X.X.X",
              "requester": null,
              "status": "reserved",
              "type": "gateway"
            },
            {
              "alias_domain": "toto.com",
              "alias_name": "",
              "description": "this is a test",
              "dns_domain": "",
              "environnement": "test",
              "fdqn": "XXX",
              "hostname": "XXX",
              "ip": "X.X.X.X",
              "requester": "XXX",
              "status": "allocated",
              "type": "VM"
            },
            {
              "alias_domain": "toto.com",
              "alias_name": "",
              "description": "this is a test",
              "dns_domain": "",
              "environnement": "test",
              "fdqn": "XXX",
              "hostname": "XXX",
              "ip": "X.X.X.X",
              "requester": "XXX",
              "status": "allocated",
              "type": "VM"
            },
            {
              "ip": "X.X.X.X",
              "status": "reserved"
            },
            {
              "ip": "X.X.X.X",
              "status": "reserved"
            },
            {
              "ip": "X.X.X.X",
              "status": "reserved"
            },
            {
              "ip": "X.X.X.X",
              "status": "reserved"
            },
            {
              "alias_domain": null,
              "alias_name": null,
              "description": "This is the broadcast address for X.X.X.X/27",
              "dnr_rr": null,
              "dns_domain": null,
              "environnement": null,
              "fdqn": null,
              "hostname": null,
              "ip": "X.X.X.X",
              "requester": null,
              "status": "reserved",
              "type": "broadcast"
            }
          ]
        },
        "output": [
          {
            "ip": "X.X.X.X",
            "status": "reserved"
          },
          {
            "ip": "X.X.X.X",
            "status": "reserved"
          },
          {
            "ip": "X.X.X.X",
            "status": "reserved"
          },
          {
            "ip": "X.X.X.X",
            "status": "reserved"
          }
        ]
      }
    ],
    "identifier": 65717880
  },
  {
    "context": [
      "I would like to pass this output through JQ to have one Objects[] list, concatenating all of the objects within the two lists, and outputting the same overall structure.",
      "You can use `reduce`:\n\n```jq\njq -s 'reduce .[] as $item ({ Quiet: false }; .Objects += $item.Objects)'\n```",
      "As @oguz-ismail suggested in a comment, the `-s` (slurp) flag can be removed by using `inputs` to get the rest of the entries after the first one:\n\n```jq\njq 'reduce inputs as $item (.; .Objects += $item.Objects)'\n```",
      "You don't need to invoke JQ twice there. The second object can be fetched using the [`input`](https://stedolan.github.io/jq/manual/#input) keyword.\n```\n.Objects += input.Objects\n```"
    ],
    "utterance": "Combine the Objects arrays from multiple structurally identical objects in a single file into one Objects array, preserving the original structure with Quiet: false.",
    "expressions": [
      "jq -s 'reduce .[] as $item ({ Quiet: false }; .Objects += $item.Objects)'",
      "jq 'reduce inputs as $item (.; .Objects += $item.Objects)'",
      ".Objects += input.Objects"
    ],
    "data": [
      {
        "input": [
          {
            "Objects": [
              {
                "Key": "somevalue",
                "VersionId": "someversion"
              }
            ],
            "Quiet": false
          },
          {
            "Objects": [
              {
                "Key": "someothervalue",
                "VersionId": "someotherversion"
              }
            ],
            "Quiet": false
          }
        ],
        "output": {
          "Objects": [
            {
              "Key": "somevalue",
              "VersionId": "someversion"
            },
            {
              "Key": "someothervalue",
              "VersionId": "someotherversion"
            }
          ],
          "Quiet": false
        }
      }
    ],
    "identifier": 65813245
  },
  {
    "context": [
      "How would I, using `jq`, replace the `null` (i.e., the value of \"compare_model\") with the value from the \"name\" key?",
      ".models[] |= (.tests[].\"dbt_utils.equal_rowcount\".compare_model = \"(\\(.name))\")",
      ".models |= \n  map(.name as $name\n      | (.tests[].\"dbt_utils.equal_rowcount\".compare_model =\n         $name))",
      ".models |= \n  map(\"(\\(.name))\" as $name\n      | (.tests[].\"dbt_utils.equal_rowcount\".compare_model =\n         $name))"
    ],
    "utterance": "Replace the value of each compare_model field with the corresponding name field's value from the same model, wrapping the value in parentheses.",
    "expressions": [
      ".models[] |= (.tests[].\"dbt_utils.equal_rowcount\".compare_model = \"(\\(.name))\")",
      ".models |= map(\"(\\(.name))\" as $name | (.tests[].\"dbt_utils.equal_rowcount\".compare_model = $name))"
    ],
    "data": [
      {
        "input": {
          "version": 2,
          "models": [
            {
              "name": "first_table",
              "tests": [
                {
                  "dbt_utils.equal_rowcount": {
                    "compare_model": null
                  }
                }
              ]
            },
            {
              "name": "second_table",
              "tests": [
                {
                  "dbt_utils.equal_rowcount": {
                    "compare_model": null
                  }
                }
              ]
            }
          ]
        },
        "output": {
          "version": 2,
          "models": [
            {
              "name": "first_table",
              "tests": [
                {
                  "dbt_utils.equal_rowcount": {
                    "compare_model": "(first_table)"
                  }
                }
              ]
            },
            {
              "name": "second_table",
              "tests": [
                {
                  "dbt_utils.equal_rowcount": {
                    "compare_model": "(second_table)"
                  }
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 65821660
  },
  {
    "context": [
      "when piping this to `jq`, I get:\n\n`parse error: Invalid numeric literal at line 1, column 2`",
      "If looking at the JSON returned from `aws` in a binary editor, or using `jq`:s `inputs` feature, I see that it contains a lot of control codes:",
      "These control codes, e.g. `\\u001b[m`, look like ANSI codes to control formatting such as bold, colors etc.",
      "Is there a simple tool to strip them away so that I can continue using the dockerized AWS CLI v2 and pipe the output to `jq`?",
      "The correct fix is to remove `-it` - [it&#39;s only there for when you need to provide interactive input][2], and if you&#39;re piping the output to jq then you don&#39;t need or want interactive input.",
      "Alternatively you can pass `--no-cli-pager` or set the environment variable `AWS_PAGER` to `cat`"
    ],
    "utterance": "Remove ANSI control codes from the output so it can be processed without parse errors.",
    "expressions": [
      "aws logs describe-log-groups --no-cli-pager | jq",
      "AWS_PAGER=cat aws logs describe-log-groups | jq"
    ],
    "identifier": 65824304
  },
  {
    "context": [
      "Basically I want to merge each `value` array of objects into a single `values` array underneath the `data` array.",
      "Flattening can be done via the idiomatic expression **del(A) + A[]** here, and what's left is construction of the surrounding structure, which is trivial.",
      "``` none\n.data |= [{values: map(del(.value) + .value[])}]\n```"
    ],
    "utterance": "Transform each object's 'value' array within 'data' into a single 'values' array that merges each object's top-level fields with each of its 'value' array elements.",
    "expressions": [
      ".data |= [{values: map(del(.value) + .value[])}]"
    ],
    "data": [
      {
        "input": {
          "data": [
            {
              "id": 1,
              "error": "error1",
              "key": "key1",
              "value": [
                {
                  "class_name": "namespace_read",
                  "in_max": 148,
                  "in_min": 112,
                  "in_rate": 359750.71875
                },
                {
                  "class_name": "namespace_write",
                  "in_max": 184,
                  "in_min": 152,
                  "in_rate": 656.1185913085938
                },
                {
                  "class_name": "namespace_test",
                  "in_max": 152,
                  "in_min": 152,
                  "in_rate": 29.93098068237305
                }
              ]
            },
            {
              "id": 2,
              "error": "error2",
              "key": "key2",
              "value": [
                {
                  "class_name": "namespace_read",
                  "in_max": 156,
                  "in_min": 112,
                  "in_rate": 459885.03125
                },
                {
                  "class_name": "namespace_write",
                  "in_max": 176,
                  "in_min": 152,
                  "in_rate": 8970.888671875
                },
                {
                  "class_name": "namespace_test",
                  "in_max": 152,
                  "in_min": 152,
                  "in_rate": 262.3605346679688
                }
              ]
            }
          ]
        },
        "output": {
          "data": [
            {
              "values": [
                {
                  "id": 1,
                  "error": "error1",
                  "key": "key1",
                  "class_name": "namespace_read",
                  "in_max": 148,
                  "in_min": 112,
                  "in_rate": 359750.71875
                },
                {
                  "id": 1,
                  "error": "error1",
                  "key": "key1",
                  "class_name": "namespace_write",
                  "in_max": 184,
                  "in_min": 152,
                  "in_rate": 656.1185913085938
                },
                {
                  "id": 1,
                  "error": "error1",
                  "key": "key1",
                  "class_name": "namespace_test",
                  "in_max": 152,
                  "in_min": 152,
                  "in_rate": 29.93098068237305
                },
                {
                  "id": 2,
                  "error": "error2",
                  "key": "key2",
                  "class_name": "namespace_read",
                  "in_max": 156,
                  "in_min": 112,
                  "in_rate": 459885.03125
                },
                {
                  "id": 2,
                  "error": "error2",
                  "key": "key2",
                  "class_name": "namespace_write",
                  "in_max": 176,
                  "in_min": 152,
                  "in_rate": 8970.888671875
                },
                {
                  "id": 2,
                  "error": "error2",
                  "key": "key2",
                  "class_name": "namespace_test",
                  "in_max": 152,
                  "in_min": 152,
                  "in_rate": 262.3605346679688
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 65800468
  },
  {
    "context": [
      "One solution could be to provide the path as a json array, and then use `getpath` to convert that to a path:",
      "field='[\"level1\", \"level2\", \"level3\"]'",
      "jq -r --argjson f \"$field\" 'getpath($f) | to_entries | .[] | \"\\\"\" + .key + \"\\\"=\\\"\" + .value + \"\\\"\"' <<< ${DATA}",
      "Unless any of the path components contain a dot, splitting `$f` by dots and using the result as argument to `getpath` should work.",
      "getpath($f / \".\")"
    ],
    "utterance": "Access all key-value pairs at the nested path specified as a dot-separated string or JSON array, such as 'level1.level2.level3', and format each as '\"key\"=\"value\"'.",
    "expressions": [
      "getpath($f) | to_entries | .[] | \"\\\"\" + .key + \"\\\"=\\\"\" + .value + \"\\\"\"",
      "getpath($f / \".\") | to_entries | .[] | \"\\\"\" + .key + \"\\\"=\\\"\" + .value + \"\\\"\""
    ],
    "data": [
      {
        "input": {
          "level1": {
            "level2": {
              "level3": {
                "foo": "bar",
                "bar": "baz",
                "baz": "bar"
              }
            }
          }
        },
        "output": [
          "\"foo\"=\"bar\"",
          "\"bar\"=\"baz\"",
          "\"baz\"=\"bar\""
        ]
      }
    ],
    "identifier": 65827548
  },
  {
    "context": [
      "In a json like above I need to get extract the following details. Assuming that I have to extract the key and the value both.",
      "test1=foo",
      "test2=bar",
      "Found the answer. You can do it by the following code.",
      "jq -r 'keys[] as $k | \"\\($k) \\(.[$k].value)\"' tmp.json"
    ],
    "utterance": "Extract each object's key and its 'value' field as key=value pairs.",
    "expressions": [
      "jq -r 'keys[] as $k | \"\\($k)=\\(.[$k].value)\"'"
    ],
    "data": [
      {
        "input": {
          "test1": {
            "type": "string",
            "value": "foo"
          },
          "test2": {
            "type": "string",
            "value": "bar"
          }
        },
        "output": [
          "test1=foo",
          "test2=bar"
        ]
      }
    ],
    "identifier": 65831486
  },
  {
    "context": [
      "I want split with space Mario from Luigi.",
      "jq --compact-output 'select(.contact_type | contains(\"tecnico\")) | {FirstName: .first_name},{LastName: .last_name},{Email: .email}'",
      "Assuming the input is fixed and that each object has a \"technico\" field, you can run the following:\n```\njq -r -c '\n  select(.contact_type | contains(\"tecnico\"))\n  | {FirstName: .first_name},{LastName: .last_name},{Email: .email}, \"\"\n'\n```",
      "The -r option suppresses the quotation marks around the top-level string, and the trailing `, \"\"` has the effect of adding a new-line after each object."
    ],
    "utterance": "Show FirstName, LastName, and Email fields for each object containing 'tecnico' in contact_type, separated by a blank line between groups.",
    "expressions": [
      "jq -r -c 'select(.contact_type | contains(\"tecnico\")) | {FirstName: .first_name},{LastName: .last_name},{Email: .email}, \"\"'"
    ],
    "data": [
      {
        "input": [
          {
            "first_name": "Mario",
            "last_name": "Bros",
            "email": "mario.bros@mario.com",
            "contact_type": "tecnico"
          },
          {
            "first_name": "Luigi",
            "last_name": "Bros",
            "email": "luigi.bros@mario.com",
            "contact_type": "tecnico"
          }
        ],
        "output": "{\n\"FirstName\":\"Mario\"\n}\n{\"LastName\":\"Bros\"\n}\n{\"Email\":\"mario.bros@mario.com\"\n}\n\n{\"FirstName\":\"Luigi\"\n}\n{\"LastName\":\"Bros\"\n}\n{\"Email\":\"luigi.bros@mario.com\"\n}\n"
      }
    ],
    "identifier": 65830936
  },
  {
    "context": [
      "I have the following nested JSON file `labs.json` with variable keywords (`lab001`, `lab002`, etc.) which I would like to convert into a TSV using `jq`:",
      "keys_unsorted[] as $id | [$id, (.[$id].tags[] | join(\",\"))] | @tsv"
    ],
    "utterance": "Transform a nested object with variable lab IDs and tags to a TSV where each row starts with the lab ID and is followed by all tag arrays joined by commas.",
    "expressions": [
      "keys_unsorted[] as $id | [$id, (.[$id].tags[] | join(\",\"))] | @tsv"
    ],
    "data": [
      {
        "input": {
          "lab001": {
            "tags": {
              "T1": [],
              "T2": [
                "k26",
                "e23"
              ],
              "T3": [
                "s92"
              ]
            },
            "code": "8231"
          },
          "lab002": {
            "tags": {
              "T1": [
                "t32",
                "y55"
              ],
              "T2": [
                "q78"
              ],
              "T3": [
                "b24"
              ]
            },
            "code": "9112"
          }
        },
        "output": "lab001\t\tk26,e23\ts92\nlab002\tt32,y55\tq78\tb24"
      }
    ],
    "identifier": 65831692
  },
  {
    "context": [
      "So I prefer deleting request cookies before sharing the HAR file.",
      "To indiscriminately delete all request.cookies:",
      "    jq 'del(.. | .request?.cookies?)' www.ibm.com.har"
    ],
    "utterance": "Remove all values under the cookies field inside each request before sharing the file.",
    "expressions": [
      "jq 'del(.. | .request?.cookies?)' www.ibm.com.har"
    ],
    "identifier": 65853586
  },
  {
    "context": [
      "How do I iterate the loop using shell script so that using a single script, it outputs the value of `name` for all the names in the array?",
      "How can I create a script that automatically fetches however many times `name` appears in the `items` array and then prints them one by one? Is it possible using some `for` or `while` loop?"
    ],
    "utterance": "Output the value of the field 'name' for each element in the 'items' array.",
    "expressions": [
      ".items[].name"
    ],
    "data": [
      {
        "input": {
          "items": [
            {
              "name": "foo"
            },
            {
              "name": "bar"
            },
            {
              "name": "baz"
            }
          ]
        },
        "output": [
          "foo",
          "bar",
          "baz"
        ]
      }
    ],
    "identifier": 65854485
  },
  {
    "context": [
      "I have a plain text file in format like this:\r\n```\r\nfoo: bar\r\ncolor: blue\r\nnames: joe, john, mary, bob, sue\r\n```",
      "I need to output the contents of this file as a JSON format:\r\n```\r\n{\r\n  \"foo\": \"bar\",\r\n  \"color\": \"blue\",\r\n  \"names\": [\"joe\", \"john\", \"mary\", \"bob\", \"sue\"]\r\n}\r\n```",
      "Always split the value. If resulting array has multiple elements, then assign it; otherwise assign the original string.\r\n``` none\r\nreduce (inputs / \": \") as [$k, $v] (.;\r\n  .[$k] = ($v / \", \" | if has(1) then . else $v end)\r\n)\r\n```",
      "Or, check whether the value contains a separator first and then split, if that makes more sense.\r\n``` none\r\n          ($v | if index(\", \") then split(\", \") else . end)\r\n```",
      "With `--raw-input`, you're looking for something like this:\r\n\r\n```\r\n  [., inputs]                                                              # A\r\n| map(split(\": \")                                                          # B\r\n  | {(.[0]): (.[1] | split(\", \") | if length > 1 then . else .[0] end )})  # C\r\n| reduce .[] as $x ({}; . + $x)                                            # D\r\n\r\n```"
    ],
    "utterance": "Convert key-value pairs from plain text where some values are comma-separated lists into an object, using arrays for lists and strings for single values.",
    "expressions": [
      "reduce (inputs / \": \") as [$k, $v] (.;\n  .[$k] = ($v / \", \" | if has(1) then . else $v end)\n)",
      "reduce (inputs / \": \") as [$k, $v] (.;\n  .[$k] = ($v | if index(\", \") then split(\", \") else . end)\n)",
      "[., inputs] | map(split(\": \") | {(.[0]): (.[1] | split(\", \") | if length > 1 then . else .[0] end )}) | reduce .[] as $x ({}; . + $x)"
    ],
    "data": [
      {
        "input": "foo: bar\ncolor: blue\nnames: joe, john, mary, bob, sue",
        "output": {
          "foo": "bar",
          "color": "blue",
          "names": [
            "joe",
            "john",
            "mary",
            "bob",
            "sue"
          ]
        }
      }
    ],
    "identifier": 65832707
  },
  {
    "context": [
      "Given that input issued from terraform:\r\n\r\n```JSON\r\n{\r\n  \"cost\": {\r\n    \"sensitive\": false,\r\n    \"value\": \"123\"\r\n  },\r\n  \"test_id\": {\r\n    \"sensitive\": false,\r\n    \"value\": \"6610758455459338306\"\r\n  }\r\n}\r\n```",
      "How do i convert it to something usefull for my application like bellow:\r\n\r\n```JSON\r\n{\r\n  \"cost\": \"123\",\r\n  \"test_id\": \"6610758455459338306\"\r\n}\r\n```",
      "map_values(.value)",
      "with_entries(.value = .value.value)"
    ],
    "utterance": "Extract each object's 'value' field and construct a new object with the same keys and those values.",
    "expressions": [
      "map_values(.value)",
      "with_entries(.value = .value.value)"
    ],
    "data": [
      {
        "input": {
          "cost": {
            "sensitive": false,
            "value": "123"
          },
          "test_id": {
            "sensitive": false,
            "value": "6610758455459338306"
          }
        },
        "output": {
          "cost": "123",
          "test_id": "6610758455459338306"
        }
      }
    ],
    "identifier": 65883327
  },
  {
    "context": [
      "Have some records in a json that I want to sort by date",
      "I have tried with this:\n```\njq '.[] | .lastConfigChangeAt | sort_by(.lastConfigChangeAt)'\n```",
      "ERROR: \njq: error (at <stdin>:17): Cannot iterate over string (\"2020-12-11...",
      "So, thanks to ISO 8601, the filter would be just that:",
      "    sort_by(.lastConfigChangeAt)\n\n(That\u2019s the entire jq program.)"
    ],
    "utterance": "Sort objects by the lastConfigChangeAt field in ascending order.",
    "expressions": [
      "sort_by(.lastConfigChangeAt)"
    ],
    "data": [
      {
        "input": [
          {
            "lastScalingAt": "2020-12-11T17:29:35.888Z",
            "lastConfigChangeAt": "2020-12-11T17:29:35.888Z"
          },
          {
            "lastScalingAt": "2020-12-11T17:29:38.655Z",
            "lastConfigChangeAt": "2020-12-11T17:29:38.655Z"
          },
          {
            "lastScalingAt": "2020-12-11T17:29:37.233Z",
            "lastConfigChangeAt": "2020-12-11T17:29:37.233Z"
          },
          {
            "lastScalingAt": "2020-12-08T20:42:09.990Z",
            "lastConfigChangeAt": "2020-03-30T16:23:59.682Z"
          }
        ],
        "output": [
          {
            "lastScalingAt": "2020-12-08T20:42:09.990Z",
            "lastConfigChangeAt": "2020-03-30T16:23:59.682Z"
          },
          {
            "lastScalingAt": "2020-12-11T17:29:35.888Z",
            "lastConfigChangeAt": "2020-12-11T17:29:35.888Z"
          },
          {
            "lastScalingAt": "2020-12-11T17:29:37.233Z",
            "lastConfigChangeAt": "2020-12-11T17:29:37.233Z"
          },
          {
            "lastScalingAt": "2020-12-11T17:29:38.655Z",
            "lastConfigChangeAt": "2020-12-11T17:29:38.655Z"
          }
        ]
      }
    ],
    "identifier": 65860494
  },
  {
    "context": [
      "I want to change all status \"reserved\" as \"available\" without changing the status for the ip which have network, gateway or broadcast as status.",
      "But there is a way to do that in order to have this output : ... Display all the data with the changes desired not just display the lines which should be changed ?",
      "You can choose between a straightforward approach, such as:\n```\n.ipAddressTab\n |= map(if .status == \"reserved\" \n           and .type != \"network\"\n           and .type != \"gateway\"\n           and .type != \"broadcast\"\n        then .status = \"available\" else . end)\n```",
      "or the more subtle:\n```\n(.ipAddressTab[]\n | select(.status == \"reserved\" and \n          .type != \"network\" and\n          .type != \"gateway\" and\n          .type != \"broadcast\")\n).status = \"available\"\n```",
      "Incidentally, a DRYer version of either approach can be obtained by using `IN`: \n```\n.type | IN(\"network\", \"gateway\", \"broadcast\") | not\n```"
    ],
    "utterance": "Update all objects in ipAddressTab where status is \"reserved\" and type is not \"network\", \"gateway\", or \"broadcast\" to set status to \"available\", and display the entire data structure with these changes.",
    "expressions": [
      ".ipAddressTab |= map(if .status == \"reserved\" and (.type | IN(\"network\", \"gateway\", \"broadcast\") | not) then .status = \"available\" else . end)",
      "(.ipAddressTab[] | select(.status == \"reserved\" and (.type | IN(\"network\", \"gateway\", \"broadcast\") | not))).status = \"available\""
    ],
    "data": [
      {
        "input": {
          "cidr": "X.X.X.X/27",
          "defaultGateway": "X.X.X.X",
          "full": false,
          "id": "X.X.X.X",
          "ipAddressTab": [
            {
              "alias_domain": null,
              "alias_name": null,
              "description": "This is the network address for X.X.X.X/27",
              "dnr_rr": null,
              "dns_domain": null,
              "environnement": null,
              "fdqn": null,
              "hostname": null,
              "ip": "X.X.X.X",
              "requester": null,
              "status": "reserved",
              "type": "network"
            },
            {
              "alias_domain": null,
              "alias_name": null,
              "description": "This is the default gateway address for X.X.X.X/27",
              "dnr_rr": null,
              "dns_domain": null,
              "environnement": null,
              "fdqn": null,
              "hostname": null,
              "ip": "X.X.X.X",
              "requester": null,
              "status": "reserved",
              "type": "gateway"
            },
            {
              "alias_domain": "toto.com",
              "alias_name": "",
              "description": "this is a test",
              "dns_domain": "",
              "environnement": "test",
              "fdqn": "XXX",
              "hostname": "XXX",
              "ip": "X.X.X.X",
              "requester": "XXX",
              "status": "allocated",
              "type": "VM"
            },
            {
              "alias_domain": "toto.com",
              "alias_name": "",
              "description": "this is a test",
              "dns_domain": "",
              "environnement": "test",
              "fdqn": "XXX",
              "hostname": "XXX",
              "ip": "X.X.X.X",
              "requester": "XXX",
              "status": "allocated",
              "type": "VM"
            },
            {
              "ip": "X.X.X.X",
              "status": "reserved"
            },
            {
              "ip": "X.X.X.X",
              "status": "reserved"
            },
            {
              "ip": "X.X.X.X",
              "status": "reserved"
            },
            {
              "ip": "X.X.X.X",
              "status": "reserved"
            },
            {
              "alias_domain": null,
              "alias_name": null,
              "description": "This is the broadcast address for X.X.X.X/27",
              "dnr_rr": null,
              "dns_domain": null,
              "environnement": null,
              "fdqn": null,
              "hostname": null,
              "ip": "X.X.X.X",
              "requester": null,
              "status": "reserved",
              "type": "broadcast"
            }
          ]
        },
        "output": {
          "cidr": "X.X.X.X/27",
          "defaultGateway": "X.X.X.X",
          "full": false,
          "id": "X.X.X.X",
          "ipAddressTab": [
            {
              "alias_domain": null,
              "alias_name": null,
              "description": "This is the network address for X.X.X.X/27",
              "dnr_rr": null,
              "dns_domain": null,
              "environnement": null,
              "fdqn": null,
              "hostname": null,
              "ip": "X.X.X.X",
              "requester": null,
              "status": "reserved",
              "type": "network"
            },
            {
              "alias_domain": null,
              "alias_name": null,
              "description": "This is the default gateway address for X.X.X.X/27",
              "dnr_rr": null,
              "dns_domain": null,
              "environnement": null,
              "fdqn": null,
              "hostname": null,
              "ip": "X.X.X.X",
              "requester": null,
              "status": "reserved",
              "type": "gateway"
            },
            {
              "alias_domain": "toto.com",
              "alias_name": "",
              "description": "this is a test",
              "dns_domain": "",
              "environnement": "test",
              "fdqn": "XXX",
              "hostname": "XXX",
              "ip": "X.X.X.X",
              "requester": "XXX",
              "status": "allocated",
              "type": "VM"
            },
            {
              "alias_domain": "toto.com",
              "alias_name": "",
              "description": "this is a test",
              "dns_domain": "",
              "environnement": "test",
              "fdqn": "XXX",
              "hostname": "XXX",
              "ip": "X.X.X.X",
              "requester": "XXX",
              "status": "allocated",
              "type": "VM"
            },
            {
              "ip": "X.X.X.X",
              "status": "available"
            },
            {
              "ip": "X.X.X.X",
              "status": "available"
            },
            {
              "ip": "X.X.X.X",
              "status": "available"
            },
            {
              "ip": "X.X.X.X",
              "status": "available"
            },
            {
              "alias_domain": null,
              "alias_name": null,
              "description": "This is the broadcast address for X.X.X.X/27",
              "dnr_rr": null,
              "dns_domain": null,
              "environnement": null,
              "fdqn": null,
              "hostname": null,
              "ip": "X.X.X.X",
              "requester": null,
              "status": "reserved",
              "type": "broadcast"
            }
          ]
        }
      }
    ],
    "identifier": 65720697
  },
  {
    "context": [
      "I need to extract the name and price so that it looks like this:\r\n{\r\n  \"itemname\": \"16 GB\",\r\n  \"itemprice\": \"GBP 62.99\"\r\n}\r\n{\r\n  \"itemname\": \"4 GB\",\r\n  \"itemprice\": \"GBP 15.00\"\r\n}",
      "The easiest way to achieve this would be to keep `itemVariationsMap` in a variable, and retrieve item prices from there; not the other way around.",
      ".itmVarModel\n| .itemVariationsMap as $m\n| .menuItemMap[]\n| { itemname: .displayName, itemprice: $m[\"\\(.matchingVariationIds[0])\"].price }"
    ],
    "utterance": "List each menu item with its display name and price, matching by the variation ID in matchingVariationIds.",
    "expressions": [
      ".itmVarModel\n| .itemVariationsMap as $m\n| .menuItemMap[]\n| { itemname: .displayName, itemprice: $m[\"\\(.matchingVariationIds[0])\"].price }"
    ],
    "data": [
      {
        "input": {
          "itmVarModel": {
            "menuItemMap": {
              "0": {
                "matchingVariationIds": [
                  1234
                ],
                "displayName": "4 GB"
              },
              "1": {
                "matchingVariationIds": [
                  5678
                ],
                "displayName": "16 GB"
              }
            },
            "itemVariationsMap": {
              "5678": {
                "price": "GBP 62.99",
                "variationId": 5678
              },
              "1234": {
                "price": "GBP 15.00",
                "variationId": 1234
              }
            }
          }
        },
        "output": [
          {
            "itemname": "4 GB",
            "itemprice": "GBP 15.00"
          },
          {
            "itemname": "16 GB",
            "itemprice": "GBP 62.99"
          }
        ]
      }
    ],
    "identifier": 65886484
  },
  {
    "context": [
      "What is a `jq` command to list the lengths of all array fields in the top-level object?",
      "The output I&#39;m looking for would be something like:\r\n{\r\n  \"payload 1\": 2,\r\n  \"another payload\": 4\r\n}",
      "map_values(arrays | length)"
    ],
    "utterance": "List the keys and lengths of all fields whose values are arrays at the top level of the object.",
    "expressions": [
      "map_values(arrays | length)"
    ],
    "data": [
      {
        "input": {
          "header 1": 42,
          "header 2": "2020-01-27",
          "payload 1": [
            {
              "foo": 1
            },
            {
              "foo": 2
            }
          ],
          "another payload": [
            10,
            9,
            8,
            7
          ]
        },
        "output": {
          "payload 1": 2,
          "another payload": 4
        }
      }
    ],
    "identifier": 65910229
  },
  {
    "context": [
      "I would like to add list and append some text between the value and have output like this:",
      "One way to join two strings is with `+`, e.g. instead of\n    name: .something1\nyou would write\n    name: (\"NewName.\" + .something1)",
      "Taking your query as a starting point, the next step would be to wrap everything in an object with `Newlist` as the key:",
      "{ Newlist:\n    .list\n    | map({name: (\"NewName.\" + .something1),\n           HaveItem:\n             (if .status.totalItems != 0 \n              then \"Yes\" \n              else \"No\" end),\n   \t       Data: \n             (if .status.totalItems != 0\n              then .status.Items\n              else \"NULL\" end)\n\t} ) }"
    ],
    "utterance": "Transform the input by creating a top-level key 'Newlist' whose value is an array of objects with 'name' as 'NewName.' concatenated with 'something1', 'HaveItem' as 'Yes' if 'status.totalItems' is not 0 (otherwise 'No'), and if there are items, 'Data' as an array of strings in the form 'city is a city of state with address adress' for each item in 'status.Items'.",
    "expressions": [
      "{ Newlist: [ .list[] | { name: (\"NewName.\" + .something1), HaveItem: (if .status.totalItems != 0 then \"Yes\" else \"No\" end), Data: (if .status.totalItems != 0 then [.status.Items[] | \"\\(.city) is a city of \\(.state) with address \\(.adress)\"] else empty end) } ] }"
    ],
    "data": [
      {
        "input": {
          "list": [
            {
              "something1": "aaaa",
              "status": {
                "totalItems": 2,
                "Items": [
                  {
                    "city": "santa",
                    "state": "VA",
                    "adress": "1 avenue"
                  },
                  {
                    "city": "manhatan",
                    "state": "NY",
                    "adress": "1 drive"
                  }
                ]
              }
            },
            {
              "something1": "bbbb",
              "status": {
                "totalItems": 0
              }
            }
          ]
        },
        "output": {
          "Newlist": [
            {
              "name": "NewName.aaaa",
              "HaveItem": "Yes",
              "Data": [
                "santa is a city of VA with address 1 avenue",
                "manhatan is a city of NY with address 1 drive"
              ]
            },
            {
              "name": "NewName.bbbb",
              "HaveItem": "No"
            }
          ]
        }
      }
    ],
    "identifier": 65877650
  },
  {
    "context": [
      "How to add `grp:` prefix for each found group?",
      "Expected output would be:\n\n    u1      u1      grp:G1|grp:G2\n    u2      u2      grp:-",
      "Use `+` to concatenate strings:",
      "jq -r '.[]\n       | [.login, .name, (\n           (\n               if .groups == null\n               then [\"-\"]\n               else (\n                   del(.groups[] | select(.name==\"All Users\"))\n                   | [.groups[].name]\n               )\n               end\n           )\n           | map(\"grp:\" + .)\n           | join(\"|\")\n       )]\n       | @tsv'",
      "Getting inspiration from *peak* I guess this produces the output you wanted:",
      "jq -r '.[]\n        | .groups //= []\n        | del(.groups[] | select(.name==\"All Users\"))\n        | .groups[0] //= {name: \"-\"}\n        | [.login, .name, ( [\"grp:\" + (.groups[].name)] | join(\"|\") ) ]\n        | @tsv'",
      "Here's a slightly shorter and perhaps tidier variant of the solution already given. It has the advantage of handling the edge case mentioned in a comment elsewhere on this page.",
      ".[]\n  | .groups //= [{name: \"-\"}]\n  | [.login,\n     .name,\n     (del(.groups[] | select(.name==\"All Users\"))\n     | [\"grp:\" + (.groups[].name)] | join(\"|\")) \n    ]\n  | @tsv",
      "Simpler still\n \n.groups //= [{name: \"-\"}]\n  | .groups |= map(select( .name != \"All Users\") )\n  | [.login, .name,\n     (.groups | map(\"grp:\" + .name) | join(\"|\")) ]\n  | @tsv"
    ],
    "utterance": "Output each user's login, name, and their group names prefixed by 'grp:' (or 'grp:-' if groups is null), separated by '|', skipping any group named 'All Users'.",
    "expressions": [
      ".[] | [.login, .name, ( (if .groups == null then [\"-\"] else (del(.groups[] | select(.name==\"All Users\")) | [.groups[].name]) end) | map(\"grp:\" + .) | join(\"|\")) ] | @tsv",
      ".[] | .groups //= [] | del(.groups[] | select(.name==\"All Users\")) | .groups[0] //= {name: \"-\"} | [.login, .name, ([\"grp:\" + (.groups[].name)] | join(\"|\")) ] | @tsv",
      ".[] | .groups //= [{name: \"-\"}] | [.login, .name, (del(.groups[] | select(.name==\"All Users\")) | [\"grp:\" + (.groups[].name)] | join(\"|\")) ] | @tsv",
      ".groups //= [{name: \"-\"}] | .groups |= map(select(.name != \"All Users\")) | [.login, .name, (.groups | map(\"grp:\" + .name) | join(\"|\")) ] | @tsv"
    ],
    "data": [
      {
        "input": [
          {
            "login": "u1",
            "name": "u1",
            "role": "User",
            "groups": [
              {
                "id": "1234",
                "name": "G1"
              },
              {
                "id": "1235",
                "name": "G2"
              }
            ],
            "created": "2020-05-11 11:06"
          },
          {
            "login": "u2",
            "name": "u2",
            "role": "User",
            "groups": null,
            "created": "2020-05-11 11:06"
          }
        ],
        "output": "u1\tu1\tgrp:G1|grp:G2\nu2\tu2\tgrp:-"
      }
    ],
    "identifier": 65833864
  },
  {
    "context": [
      "I have thousands of JSON files, and I want to merge them into a single one.",
      "I'm using the command below to do this.",
      "jq -s . -- *.json > result.json",
      "But I am getting argument list too long error, probably because of the number of files I'm trying to merge. Is there any workaround for this issue?",
      "printf '%s\\0' *.json | xargs -0 cat -- | jq -s ."
    ],
    "utterance": "Merge thousands of files into a single array, avoiding argument list too long errors.",
    "expressions": [
      "printf '%s\\0' *.json | xargs -0 cat -- | jq -s ."
    ],
    "identifier": 65933153
  },
  {
    "context": [
      "What commands should I add so I can have a result of \r\n```\r\n\"Effect\", \"ID\", \"Description\", \"Expiration Date\"\r\n\"ignore\",\"CVE-2020-8116\",\"Package dot-prop 4.2.0, status: fixed in 5.1.1, 4.2.1\",\"2021-02-27T23:00:00Z\"\r\n...",
      "a jq-only solution would be to add an array of the desired header names to your filter like so:\r\n\r\n    [\"Effect\", \"ID\", \"Description\", \"Expiration Date\"],\r\n    (.cveRules[] | [.effect, .id, .description, .expiration.date])\r\n    | @csv"
    ],
    "utterance": "Output the values of fields effect, id, description, and expiration.date for each cveRules entry as CSV rows, and include a header row with column names Effect, ID, Description, Expiration Date.",
    "expressions": [
      "[\"Effect\", \"ID\", \"Description\", \"Expiration Date\"], (.cveRules[] | [.effect, .id, .description, .expiration.date]) | @csv"
    ],
    "data": [
      {
        "input": {
          "cveRules": [
            {
              "effect": "ignore",
              "id": "CVE-2020-8116",
              "description": "Package dot-prop 4.2.0, status: fixed in 5.1.1, 4.2.1",
              "expiration": {
                "date": "2021-02-27T23:00:00Z"
              }
            },
            {
              "effect": "ignore",
              "id": "CVE-2020-8252",
              "description": "Package node 10.21.0, status: fixed in 14.9.0, 12.18.4, 10.22.1",
              "expiration": {
                "date": "2021-02-27T23:00:00Z"
              }
            },
            {
              "effect": "ignore",
              "id": "CVE-2020-8265",
              "description": "Package node 10.21.0, status: fixed in 10.23.1",
              "expiration": {
                "date": "2021-02-27T23:00:00Z"
              }
            }
          ]
        },
        "output": [
          "\"Effect\",\"ID\",\"Description\",\"Expiration Date\"",
          "\"ignore\",\"CVE-2020-8116\",\"Package dot-prop 4.2.0, status: fixed in 5.1.1, 4.2.1\",\"2021-02-27T23:00:00Z\"",
          "\"ignore\",\"CVE-2020-8252\",\"Package node 10.21.0, status: fixed in 14.9.0, 12.18.4, 10.22.1\",\"2021-02-27T23:00:00Z\"",
          "\"ignore\",\"CVE-2020-8265\",\"Package node 10.21.0, status: fixed in 10.23.1\",\"2021-02-27T23:00:00Z\""
        ]
      }
    ],
    "identifier": 65897260
  },
  {
    "context": [
      "The task: insert array from one JSON object (\"lookup\") into another (\"target\") only if the key of the \"lookup\" matches a particular \"higher-level\" value in the \"target\".",
      ".top_level |= map(\n  $lookup[.name] as $value\n  | .tests |= map(\n      if has(\"test_2\")\n      then .test_2.param_2 = $value\n      else . end) )"
    ],
    "utterance": "Insert an array from a lookup object into objects within another object when the object's name matches a key in the lookup, placing the array as param_2 in test_2 within tests.",
    "expressions": [
      ".top_level |= map(\n  $lookup[.name] as $value\n  | .tests |= map(\n      if has(\"test_2\")\n      then .test_2.param_2 = $value\n      else . end) )"
    ],
    "data": [
      {
        "input": {
          "lookup": {
            "table_one": [
              "a_col_1",
              "a_col_2"
            ],
            "table_two": [
              "b_col_1",
              "b_col_2",
              "b_col_3"
            ]
          },
          "target": {
            "top_level": [
              {
                "name": "table_one",
                "tests": [
                  {
                    "test_1": {
                      "param_1": "some_param"
                    }
                  },
                  {
                    "test_2": {
                      "param_1": "another_param"
                    }
                  }
                ]
              },
              {
                "name": "table_two",
                "tests": [
                  {
                    "test_1": {
                      "param_1": "some_param"
                    }
                  },
                  {
                    "test_2": {
                      "param_1": "another_param"
                    }
                  }
                ]
              }
            ]
          }
        },
        "output": {
          "top_level": [
            {
              "name": "table_one",
              "tests": [
                {
                  "test_1": {
                    "param_1": "some_param"
                  }
                },
                {
                  "test_2": {
                    "param_1": "another_param",
                    "param_2": [
                      "a_col_1",
                      "a_col_2"
                    ]
                  }
                }
              ]
            },
            {
              "name": "table_two",
              "tests": [
                {
                  "test_1": {
                    "param_1": "some_param"
                  }
                },
                {
                  "test_2": {
                    "param_1": "another_param",
                    "param_2": [
                      "b_col_1",
                      "b_col_2",
                      "b_col_3"
                    ]
                  }
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 65912048
  },
  {
    "context": [
      "I have a json file in which I wish to retrieve all the paths of all the keys.",
      "however, it does not show the paths which have null as their values.",
      "I wish to see path of the all nodes including those which have null as their value.",
      "This issue is covered in the [jq FAQ][1], wherein the following def for a more inclusive version of `paths` is given:",
      "def allpaths:\n  def conditional_recurse(f):  def r: ., (select(.!=null) | f | r); r;\n  path(conditional_recurse(.[]?)) | select(length > 0);"
    ],
    "utterance": "List all paths to keys, including those whose associated values are null.",
    "expressions": [
      "def allpaths: def conditional_recurse(f): def r: ., (select(.!=null) | f | r); r; path(conditional_recurse(.[]?)) | select(length > 0); allpaths"
    ],
    "data": [
      {
        "input": {
          "Root": [
            {
              "id1": "val",
              "id2": "val",
              "id3": null,
              "id4": 1,
              "id5": null,
              "id6": "val",
              "id7": {
                "id8": "val",
                "id9": "val",
                "id10": null,
                "id11": "val"
              }
            }
          ]
        }
      }
    ],
    "identifier": 65947125
  },
  {
    "context": [
      "\"I would need only some lines let's say, I would expect the output like this:\\n\\n    \\\"BIOSReleaseDate\\\": \\\"11/12/2020\\\"\\n    \\\"VersionString\\\": \\\"2.10.0\\\"\\n    \\\"CPUFamily\\\": \\\"Intel(R) Xeon(TM)\\\"\\n    \\\"DeviceDescription\\\": \\\"CPU 1\\\"\\n    \\\"DeviceDescription\\\": \\\"CPU 2\\\"\\n    \\\"IPv4Address\\\": \\\"6.6.16.16\\\"\\n    \\\"NICSpeed\\\": \\\"100\\\"\"",
      "\"With your sample, the following invocation produces the output shown below in accordance with what I take to be the requirements...\\n\\n    jq -r -f program.jq myfile.json\\n\\nwhere program.jq contains:\\n```\\n.SystemInventory[][]\\n| {BIOSReleaseDate, VersionString, CPUFamily, DeviceDescription, IPv4Address, NICSpeed}\\n| to_entries[]\\n| select(.value != null)\\n| \\\"\\\\\\\"\\\\(.key)\\\\\\\": \\\\\\\"\\\\(.value)\\\\\\\"\\\"\\n```\""
    ],
    "utterance": "Extract all BIOSReleaseDate, VersionString, CPUFamily, DeviceDescription, IPv4Address, and NICSpeed values from their corresponding objects under SystemInventory, each as separate key-value lines.",
    "expressions": [
      ".SystemInventory[][] | {BIOSReleaseDate, VersionString, CPUFamily, DeviceDescription, IPv4Address, NICSpeed} | to_entries[] | select(.value != null) | \"\\\"\\(.key)\\\": \\\"\\(.value)\\\"\""
    ],
    "data": [
      {
        "input": {
          "SystemInventory": {
            "BIOS": [
              {
                "BIOSReleaseDate": "11/12/2020",
                "FQDD": "BIOS.Setup.1-1",
                "SMBIOSPresent": "True",
                "VersionString": "2.10.0"
              }
            ],
            "CPU": [
              {
                "CPUFamily": "Intel(R) Xeon(TM)",
                "Characteristics": "64-bit capable",
                "CurrentClockSpeed": "2.2 GHz",
                "DeviceDescription": "CPU 1"
              },
              {
                "CPUFamily": "Intel(R) Xeon(TM)",
                "Characteristics": "64-bit capable",
                "CurrentClockSpeed": "2.2 GHz",
                "DeviceDescription": "CPU 2"
              }
            ],
            "iDRACNIC": [
              {
                "IPv4Address": "6.6.16.16",
                "NICDuplex": "Full",
                "NICEnabled": "Enabled",
                "NICSpeed": "100",
                "PermanentMACAddress": "5c:d8:8f:1e:51:ce"
              }
            ]
          }
        },
        "output": [
          "\"BIOSReleaseDate\": \"11/12/2020\"",
          "\"VersionString\": \"2.10.0\"",
          "\"CPUFamily\": \"Intel(R) Xeon(TM)\"",
          "\"DeviceDescription\": \"CPU 1\"",
          "\"CPUFamily\": \"Intel(R) Xeon(TM)\"",
          "\"DeviceDescription\": \"CPU 2\"",
          "\"IPv4Address\": \"6.6.16.16\"",
          "\"NICSpeed\": \"100\""
        ]
      }
    ],
    "identifier": 65924386
  },
  {
    "context": [
      "**My json.file**",
      "Then: I want it to show only the id that matches my condition",
      "The result I expect:\r\n\r\n```json\r\n{\r\n    \"id\": 1,\r\n    \"created_at\": \"2021-01-28T17:29:35.888Z\"\r\n  },\r\n```",
      "All you need is this:",
      "```jq\r\n( now | gmtime | strftime(\"%Y-%m\") ) as $this_month\n| .[]\n| select( .created_at | startswith($this_month) )\n```",
      "This nets us this:\n\n```jq\n( now | gmtime ) as $f \n| .[]\n| select(\n   .created_at\n   | strptime(\"%FT%T.%Z\")\n   | .[0] == $f[0] and .[1] == $f[1]\n)\n```"
    ],
    "utterance": "Select the object whose created_at date matches the current year and month.",
    "expressions": [
      "( now | gmtime | strftime(\"%Y-%m\") ) as $this_month | .[] | select( .created_at | startswith($this_month) )",
      "( now | gmtime ) as $f | .[] | select( .created_at | strptime(\"%FT%T.%Z\") | .[0] == $f[0] and .[1] == $f[1] )"
    ],
    "data": [
      {
        "input": [
          {
            "id": 1,
            "created_at": "2021-01-28T17:29:35.888Z"
          },
          {
            "id": 2,
            "created_at": "2020-12-11T17:29:38.655Z"
          },
          {
            "id": 3,
            "created_at": "2020-12-11T17:29:37.233Z"
          },
          {
            "id": 4,
            "created_at": "2020-03-30T16:23:59.682Z"
          }
        ]
      }
    ],
    "identifier": 65938964
  },
  {
    "context": [
      "Here is what im trying. I have tried many different ways too.",
      "jq -e -r '.results[] | .series[] | select(.values[] | contains(\"tdon\"))[]'",
      "You might like to consider:",
      "jq '.. | strings | select(contains(\"tdon\"))'",
      "the following filter would produce the result shown:",
      ".results[] | .series[][] | flatten[] | select(contains(\"tdon\")?)",
      "## Output with -r option",
      "tdonn"
    ],
    "utterance": "Find all string values containing 'tdon' and output them.",
    "expressions": [
      ".. | strings | select(contains(\"tdon\"))",
      ".results[] | .series[][] | flatten[] | select(contains(\"tdon\")?)"
    ],
    "data": [
      {
        "input": [
          [
            "user",
            "admin"
          ],
          [
            [
              "tdonn",
              true
            ]
          ]
        ],
        "output": [
          "tdonn"
        ]
      }
    ],
    "identifier": 65960107
  },
  {
    "context": [
      "The following is a response to the task described in the title:",
      "> Extract the valid portions of a mostly JSON file",
      "Given a file in which each JSON entity of interest has a type other than \"string\" and is on a single line, there is a jq solution that will extract them:",
      "    jq -nR 'inputs | fromjson? | select(type!=\"string\")' input.txt",
      "The following variant may also be of interest:",
      "    jq -nR 'inputs | fromjson?' input.txt"
    ],
    "utterance": "Extract all valid non-string objects from a file where each line may contain either a non-JSON string or a valid JSON object.",
    "expressions": [
      "jq -nR 'inputs | fromjson? | select(type!=\"string\")' input.txt",
      "jq -nR 'inputs | fromjson?' input.txt"
    ],
    "data": [
      {
        "input": "Successes: 0\nFailures: 1\n{\"name\": \"\", \"success\": false, \"error\": \"\", \"data\": {\"video\": \"\"}}",
        "output": {
          "name": "",
          "success": false,
          "error": "",
          "data": {
            "video": ""
          }
        }
      }
    ],
    "identifier": 65936470
  },
  {
    "context": [
      "How to get name value in the below json file",
      "jq -r '._class[].name' f1.json",
      "jq -r '._class.name' f1.json",
      "With your input,",
      "jq '[].name' f1.json",
      "\"actual_build\"",
      "\"CIS_TEPL_QA_Deploy\"",
      "\"cktest\"",
      "\"Create_New_DB_Structure\""
    ],
    "utterance": "Get the value of the name field for each object in the array.",
    "expressions": [
      ".[].name"
    ],
    "data": [
      {
        "input": [
          {
            "_class": "hudson.model.FreeStyleProject",
            "name": "actual_build",
            "url": "http://tepl.tallycloudinfra.com:8080/job/actual_build/",
            "color": "blue",
            "fullname": "actual_build"
          },
          {
            "_class": "hudson.model.FreeStyleProject",
            "name": "CIS_TEPL_QA_Deploy",
            "url": "http://tepl.tallycloudinfra.com:8080/job/CIS_TEPL_QA_Deploy/",
            "color": "blue",
            "fullname": "CIS_TEPL_QA_Deploy"
          },
          {
            "_class": "hudson.model.FreeStyleProject",
            "name": "cktest",
            "url": "http://tepl.tallycloudinfra.com:8080/job/cktest/",
            "color": "red",
            "fullname": "cktest"
          },
          {
            "_class": "hudson.model.FreeStyleProject",
            "name": "Create_New_DB_Structure",
            "url": "http://tepl.tallycloudinfra.com:8080/job/Create_New_DB_Structure/",
            "color": "blue",
            "fullname": "Create_New_DB_Structure"
          }
        ],
        "output": [
          "actual_build",
          "CIS_TEPL_QA_Deploy",
          "cktest",
          "Create_New_DB_Structure"
        ]
      }
    ],
    "identifier": 65950072
  },
  {
    "identifier": 66000844
  },
  {
    "context": [
      "And I want to convert or reshape into a object with the genres as the keys and the list of the films as array (comedy is only has two element in the array):",
      "\"jq 'reduce .[] as $i ({}; .[$i.genre] += [$i|del(.genre)])'\"",
      "aggregate_by(.[]; .genre; del(.genre))"
    ],
    "utterance": "Group a list of film objects by genre, setting the genre as each key with an array of films as values, and remove the genre field from each film.",
    "expressions": [
      "reduce .[] as $i ({}; .[$i.genre] += [$i|del(.genre)])",
      "aggregate_by(.[]; .genre; del(.genre))"
    ],
    "data": [
      {
        "input": [
          {
            "title": "The Great Dictator",
            "year": 1940,
            "country": "USA",
            "genre": "political satire"
          },
          {
            "title": "Modern Times ",
            "year": 1936,
            "country": "USA",
            "genre": "comedy"
          },
          {
            "title": "The Gold Rush",
            "year": 1925,
            "country": "USA",
            "genre": "comedy"
          },
          {
            "title": "The Kid",
            "year": 1921,
            "country": "USA",
            "genre": "drama"
          }
        ],
        "output": {
          "comedy": [
            {
              "title": "Modern Times ",
              "year": 1936,
              "country": "USA"
            },
            {
              "title": "The Gold Rush",
              "year": 1925,
              "country": "USA"
            }
          ],
          "political satire": [
            {
              "title": "The Great Dictator",
              "year": 1940,
              "country": "USA"
            }
          ],
          "drama": [
            {
              "title": "The Kid",
              "year": 1921,
              "country": "USA"
            }
          ]
        }
      }
    ],
    "identifier": 65974585
  },
  {
    "context": [
      "Below is my json file:\r\n```\r\n{\r\n \"name\":\"John\", \r\n  \"age\":31, \r\n \"city\":\"New York\"\r\n}\r\n```",
      "cat mytest.json| jq -r 'keys[]' | while IFS= read -r key ;  do        \necho $key \nvalue=$(jq --arg key \"$key\" -r '.[$key]' mytest.json);   \necho $value\ndone",
      "while read -r key ; do\n   read -r value\n   echo \"$key\"\n   echo \"$value\" \ndone < <(jq -r 'keys[] as $k | ($k, .[$k])' mytest.json)"
    ],
    "utterance": "Print each key and its corresponding value for each key in the top-level object.",
    "expressions": [
      "jq -r 'keys[] as $k | ($k, .[$k])' mytest.json"
    ],
    "data": [
      {
        "input": {
          "name": "John",
          "age": 31,
          "city": "New York"
        },
        "output": "name\nJohn\nage\n31\ncity\nNew York"
      }
    ],
    "identifier": 65988631
  },
  {
    "context": [
      "I am able to jq the contains part but when I add on | .id i cannot get a result",
      "I get the values of `db_contoso` and `db2_contoso`.  but I am trying to pull just the `id` based on that.",
      "So that would be to do below. Select the whole object matching the condition and get the value of `.id`",
      "jq '.restrictions[] | select(.database.value | contains(\"conto\")).id'"
    ],
    "utterance": "Extract all ids for which the associated database value contains the substring \"conto\".",
    "expressions": [
      ".restrictions[] | select(.database.value | contains(\"conto\")).id"
    ],
    "data": [
      {
        "input": {
          "restrictions": [
            {
              "id": 1,
              "database": {
                "match": "exact",
                "value": "db_contoso"
              },
              "measurement": {},
              "permissions": [
                "write"
              ]
            },
            {
              "id": 2,
              "database": {
                "match": "exact",
                "value": "db2_contoso"
              },
              "measurement": {},
              "permissions": [
                "write"
              ]
            }
          ]
        },
        "output": [
          1,
          2
        ]
      }
    ],
    "identifier": 65995981
  },
  {
    "context": [
      "I need to convert ... {\"namespace\": \"/bar/baz\", \"exports\": {\"g\": 16, \"h\": 17}} ... into ... { ... \"bar\": { \"baz\": { \"g\": 16, \"h\": 17 }}}",
      "Members must be nested under their corresponding namespace object with the only expection of members of the root \"/\" namespace which become top-level properties.",
      "Convert namespaces to paths and you can build the desired output using `getpath`/`setpath` built-ins.",
      "reduce .[] as {$namespace, $exports} ({};\n  ($namespace | ltrimstr(\"/\") | split(\"/\")) as $path\n  | setpath($path; getpath($path) + $exports)\n)"
    ],
    "utterance": "Transform an array of objects with namespace and exports so that exports are merged and nested under each basename segment of the namespace, with root namespace exports at the top level.",
    "expressions": [
      "reduce .[] as {$namespace, $exports} ({};\n  ($namespace | ltrimstr(\"/\") | split(\"/\")) as $path\n  | setpath($path; getpath($path) + $exports)\n)"
    ],
    "data": [
      {
        "input": [
          {
            "namespace": "/",
            "exports": {
              "a": 10,
              "b": 11
            }
          },
          {
            "namespace": "/",
            "exports": {
              "c": 12,
              "d": 13
            }
          },
          {
            "namespace": "/bar",
            "exports": {
              "e": 14,
              "f": 15
            }
          },
          {
            "namespace": "/bar/baz",
            "exports": {
              "g": 16,
              "h": 17
            }
          }
        ],
        "output": {
          "a": 10,
          "b": 11,
          "c": 12,
          "d": 13,
          "bar": {
            "e": 14,
            "f": 15,
            "baz": {
              "g": 16,
              "h": 17
            }
          }
        }
      }
    ],
    "identifier": 65978589
  },
  {
    "context": [
      "I want a json file that looks like this:\n```\n{\n  'folder1' : [ 'file1.pdf', 'file2.pdf', 'file3.pdf' ],\n  'folder2' : [ 'file4.pdf', 'file5.pdf', 'file6.pdf' ]\n}\n```",
      "PS. Additionally, I need to include a prefix in the name of files.",
      "jq -n 'reduce ($ARGS.positional[] / \"/\") as [$k, $v] (.; .[$k] += [\"prefix-\\($v)\"])' --args */*"
    ],
    "utterance": "Build an object mapping each folder to an array of its files, with each filename including a specified prefix.",
    "expressions": [
      "jq -n 'reduce ($ARGS.positional[] / \"/\") as [$k, $v] (.; .[$k] += [\"prefix-\\($v)\"])' --args */*"
    ],
    "identifier": 66008619
  },
  {
    "context": [
      "I am trying to retrieve the values containg contoso.  So my output in this case should just readdata_contoso and writedata_contoso but I am having issues.",
      "You are almost there. First, extract only the `name` of each role, then select those names which contain \"contoso\":",
      ".roles[].name | select(contains(\"contoso\"))"
    ],
    "utterance": "Retrieve all role names that contain the string \"contoso\".",
    "expressions": [
      ".roles[].name | select(contains(\"contoso\"))"
    ],
    "data": [
      {
        "input": {
          "roles": [
            {
              "name": "readdata_contoso",
              "permissions": {
                "": [
                  "ReadData"
                ]
              }
            },
            {
              "name": "writedata_contoso",
              "permissions": {
                "": [
                  "WriteData"
                ]
              }
            }
          ]
        },
        "output": [
          "readdata_contoso",
          "writedata_contoso"
        ]
      }
    ],
    "identifier": 66012491
  },
  {
    "context": [
      "i'm interested in objectId in the middle of the string...",
      "I need to use these objectId's",
      "Given the array of strings as shown, the following jq filter produces the ids as shown below:",
      ".[] | capture(\".*group:(?<g>[^:]*):\").g",
      "you could presumably simply split on \":\":",
      ".[] | split(\":\")[2]"
    ],
    "utterance": "Extract all group object IDs located between the second and third colons in each string of an array where the string contains 'group', for example, from 'default:group:0d275816-...' to get '0d275816-...'.",
    "expressions": [
      ".[] | capture(\".*group:(?<g>[^:]*):\").g",
      ".[] | split(\":\")[2]"
    ],
    "data": [
      {
        "input": [
          "default:group:0d275816-7a1d-4847-884d-b5c67f473973:-wx",
          "default:group:106004df-6d49-450e-a180-e5bfa1fef9b3:r-x",
          "default:group:200a2bc4-feeb-4ab5-a4c1-3cc3752fe50e:r-x",
          "default:group:956041d5-49af-4409-a2b4-67c1cf2bc433:-wx"
        ],
        "output": [
          "0d275816-7a1d-4847-884d-b5c67f473973",
          "106004df-6d49-450e-a180-e5bfa1fef9b3",
          "200a2bc4-feeb-4ab5-a4c1-3cc3752fe50e",
          "956041d5-49af-4409-a2b4-67c1cf2bc433"
        ]
      }
    ],
    "identifier": 65999976
  },
  {
    "context": [
      "I have a semi working jq filter that pulls out `.key, .value.sitename` and shows it in a one line csv format.",
      "I\u2019d like to add any `tag_*` keys and values (if found) at the end of the csv line.",
      "They all start with `tag_` but could be anything. I\u2019d like to pair the found tag name and value together if possible and append it on the csv line with the host.",
      "At the you have 2 additional columns one with the keys an other with the values in your csv file."
    ],
    "utterance": "Produce a CSV line with the key, hostname, sitename, and any keys starting with tag_ and their values, appending each tag\u2019s key and value to the line if present.",
    "expressions": [
      "[.key, .value.hostname, .value.attributes.sitename] + (.value.attributes | to_entries | map(select(.key|startswith(\"tag_\"))) | map(.key) + map(.value)) | @csv"
    ],
    "data": [
      {
        "input": {
          "key": "computer1.domain.com",
          "value": {
            "attributes": {
              "TESTID": "23423423",
              "sitename": "siteidname",
              "tag_robo_equip": "boopbeep",
              "tag_modern": "cybertruck"
            },
            "hostname": "computer1.domain.com"
          }
        },
        "output": "\"computer1.domain.com\",\"computer1.domain.com\",\"siteidname\",\"tag_robo_equip\",\"tag_modern\",\"boopbeep\",\"cybertruck\""
      }
    ],
    "identifier": 66004162
  },
  {
    "context": [
      "adding that key to the command results in keys being returned only for those two records. removing the `?` from `.contact[]?` errors out with `jq: error: Cannot iterate over null`:",
      "`curl http://localhost/test.json | jq -r '.array[] | {name: .firstname, job: .position, location: .sites[]? .officename, phone: .contact[]? .number}'`",
      "currently working around this by using the // operator as shown below. is there a more efficient or recommended way of using jq in this manner?",
      "`curl http://localhost/test.json | jq -r '.array[] | {name: .firstname, job: .position, location: .sites[]? .officename, phone: .contact[]? .number} // {name: .firstname, job: .position, location: .sites[]? .officename}'`",
      "Perhaps you are looking for a variant of your solution along the lines of:",
      "```\n.array[]\n| {name: .firstname, job: .position, location: .sites[]? .officename}\n  +  ({phone: .contact[].number}? // null)\n```",
      "(The point being that adding null to a JSON object yields the same object.)"
    ],
    "utterance": "Extract an object for each element in the array containing the firstname as name, position as job, all officename values from sites as location, and, if present, all number values from contact as phone.",
    "expressions": [
      ".array[] | {name: .firstname, job: .position, location: .sites[]? .officename, phone: .contact[]? .number} // {name: .firstname, job: .position, location: .sites[]? .officename}",
      ".array[] | {name: .firstname, job: .position, location: (.sites[]? .officename)} + ({phone: [.contact[]?.number]} | select((.phone|length) > 0))",
      ".array[] | {name: .firstname, job: .position, location: .sites[]? .officename} + ({phone: .contact[].number}? // null)"
    ],
    "data": [
      {
        "input": {
          "id": 1,
          "array": [
            {
              "firstname": "Nobody",
              "lastname": "Nothing",
              "sites": [
                {
                  "officename": "Site1",
                  "city": "City"
                }
              ],
              "position": "Test1"
            },
            {
              "firstname": "Anybody",
              "lastname": "Anything",
              "sites": [
                {
                  "officename": "Site2",
                  "city": "City2"
                }
              ],
              "position": "Test2",
              "contact": [
                {
                  "number": "123-456-7890",
                  "email": "test@test.com"
                }
              ]
            }
          ]
        },
        "output": [
          {
            "name": "Nobody",
            "job": "Test1",
            "location": "Site1"
          },
          {
            "name": "Anybody",
            "job": "Test2",
            "location": "Site2",
            "phone": "123-456-7890"
          }
        ]
      }
    ],
    "identifier": 65986890
  },
  {
    "context": [
      "Is there a way I can get TRUE/YES only if I get twice \"InService\" as an output?",
      "the following meets the functional requirements as I understand them, without requiring any further post-processing:\n```\njq -r '\n  def count(stream): reduce stream as $s (0; .+1);\n  if count(.[][] | select(.State == \"InService\")) > 1 then \"yes\" else empty end\n'\n```"
    ],
    "utterance": "Return \"yes\" only if there are at least two occurrences of \"InService\" in the State fields of all instances attached to an ELB.",
    "expressions": [
      "def count(stream): reduce stream as $s (0; .+1); if count(.[][] | select(.State == \"InService\")) > 1 then \"yes\" else empty end"
    ],
    "data": [
      {
        "input": {
          "InstanceStates": [
            {
              "InstanceId": "i-0cc1e6d50ccbXXXXX",
              "State": "InService",
              "ReasonCode": "N/A",
              "Description": "N/A"
            },
            {
              "InstanceId": "i-0fc21ddf457eXXXXX",
              "State": "InService",
              "ReasonCode": "N/A",
              "Description": "N/A"
            }
          ]
        },
        "output": "yes"
      }
    ],
    "identifier": 66014705
  },
  {
    "context": [
      "How can I print only the year component of the date?",
      "{ createdYear: ??? }",
      "Use `strptime` to convert date string to date object and then `strftime` to format the date:",
      "{ createdYear: .createdDate | strptime(\"%Y-%m-%dT%H:%M:%SZ\") | strftime(\"%Y\") }",
      "Why not just:",
      "{createdYear: .createdDate[0:4]}"
    ],
    "utterance": "Extract the year component from the 'createdDate' field formatted as 'YYYY-MM-DDThh:mm:ssZ' and output it under 'createdYear'.",
    "expressions": [
      "{ createdYear: .createdDate | strptime(\"%Y-%m-%dT%H:%M:%SZ\") | strftime(\"%Y\") }",
      "{ createdYear: .createdDate[0:4] }"
    ],
    "data": [
      {
        "input": {
          "createdDate": "2005-09-28T16:34:40Z"
        },
        "output": {
          "createdYear": "2005"
        }
      }
    ],
    "identifier": 66013045
  },
  {
    "context": [
      "I am trying to build an array using jq:",
      "jq -r --arg arg1 $(aws iam get-policy-version --policy-arn arn:aws:iam::123456789012:policy/MyPolicy --version-id v2 | jq -r --arg arg2 'MyPolicy' '.entity + {\"PolicyName\": $arg2}') '[.|length] |= . + $arg1'",
      "jq: error: syntax error, unexpected ':'",
      "Use --argjson instead of --arg in the outer invocation.",
      "jq -rn --argjson arg1 \"$output\" '. + [$arg1]'",
      "aws ... | jq --arg arg2 MyPolicy '[.entity + {\"PolicyName\": $arg2}]'"
    ],
    "utterance": "Combine the contents of the 'entity' key from a policy object with a given policy name and produce an array containing the resulting object.",
    "expressions": [
      "jq -rn --argjson arg1 \"$output\" '. + [$arg1]'",
      "jq --arg arg2 MyPolicy '[.entity + {\"PolicyName\": $arg2}]'"
    ],
    "data": [
      {
        "input": {
          "entity": {}
        },
        "output": [
          {
            "PolicyName": "MyPolicy"
          }
        ]
      }
    ],
    "identifier": 66030825
  },
  {
    "context": [
      "How can I parse this json structure with jq? It should loop over leafs (projects and groups) recursively.",
      "path = absolute path in format `/root-groups/nested-groups-level-1/nested-groups-level-2/nested-groups-level-N`",
      "Expected output:",
      "\"rootgroup1\",\"group\",\"\"",
      "\"nestedproject1\",\"project\",\"rootgroup1\"",
      "\"nestedgroup1\",\"group\",\"rootgroup1\"",
      "\"nestednestedproject2\",\"group\",\"rootgroup1/nestedgroup1\"",
      "\"rootproject1\",\"project\",\"\"",
      "\"rootgroup2\",\"group\",\"\"",
      "The following implements a solution to the problem as I understand it:",
      "def details($prefix):\n  def out:\n    select(has(\"name\") and has(\"type\")) | [.name, .type, \"/\" + ($prefix|join(\"/\"))];\n\n  out,\n    if (.nested | (. and length>0))\n    then .name as $n | .nested[] | details($prefix + [$n]) \n    else empty\n    end;\n  \n.structure[]\n| details([])\n| @csv"
    ],
    "utterance": "Recursively list each group and project with its name, type, and the full path of ancestor groups separated by slashes, outputting each as a CSV line.",
    "expressions": [
      "def details($prefix):\n  def out:\n    select(has(\"name\") and has(\"type\")) | [.name, .type, \"/\" + ($prefix|join(\"/\"))];\n\n  out,\n    if (.nested | (. and length>0))\n    then .name as $n | .nested[] | details($prefix + [$n]) \n    else empty\n    end;\n  \n.structure[]\n| details([])\n| @csv"
    ],
    "data": [
      {
        "input": {
          "structure": [
            {
              "name": "rootgroup1",
              "type": "group",
              "nested": [
                {
                  "name": "nestedproject1",
                  "type": "project"
                },
                {
                  "name": "nestedgroup1",
                  "type": "group",
                  "nested": [
                    {
                      "name": "nestednestedproject2",
                      "type": "project"
                    }
                  ]
                }
              ]
            },
            {
              "name": "rootproject1",
              "type": "project"
            },
            {
              "name": "rootgroup2",
              "type": "group",
              "nested": []
            }
          ]
        },
        "output": [
          "\"rootgroup1\",\"group\",\"/\"",
          "\"nestedproject1\",\"project\",\"/rootgroup1\"",
          "\"nestedgroup1\",\"group\",\"/rootgroup1\"",
          "\"nestednestedproject2\",\"project\",\"/rootgroup1/nestedgroup1\"",
          "\"rootproject1\",\"project\",\"/\"",
          "\"rootgroup2\",\"group\",\"/\""
        ]
      }
    ],
    "identifier": 66014841
  },
  {
    "context": [
      "I seek a solution that after piping and selects will yield either the value of the `Value` field where a key `Name` is `Name` or `(none)` as a default.",
      "It is when the `Tags` array exists but does *not* contain .Key == \"Name\" that the select yields null and no value is returned.",
      "This `jq` script should do the trick:\n```\n{\n  id,\n  name: (first(.Tags[] | select(.Key == \"Name\").Value)? // \"(none)\")\n}\n| \"\\(.id) \\(.name)\"\n```",
      "This program just tries to access `.Value` of the `Name` entry, and if that doesn't work for any reason at all, it substitutes \"(none)\"."
    ],
    "utterance": "For each object, print its id and the value associated with the 'Name' key in its Tags array, or '(none)' if no such key exists.",
    "expressions": [
      "{ id, name: (first(.Tags[] | select(.Key == \"Name\").Value)? // \"(none)\") } | \"\\(.id) \\(.name)\""
    ],
    "data": [
      {
        "input": [
          {
            "id": 0,
            "Tags": [
              {
                "Key": "Name",
                "Value": "machine1"
              },
              {
                "Key": "Stage",
                "Value": "UAT"
              }
            ]
          },
          {
            "id": 1,
            "Tags": [
              {
                "Key": "Stage",
                "Value": "UAT"
              }
            ]
          },
          {
            "id": 2,
            "Tags": []
          },
          {
            "id": 3
          }
        ],
        "output": [
          "0 machine1",
          "1 (none)",
          "2 (none)",
          "3 (none)"
        ]
      }
    ],
    "identifier": 66036175
  },
  {
    "context": [
      "How to convert the flattened JSON like following",
      "{\n  \"foo.bar1\": \"1\",\n  \"foo.bar2\": \"2\",\n  \"foo.bar3.doo1\": \"3\",\n  \"foo.bar3.doo2\" : \"4\"\n}",
      "to be nested like",
      "{\n  \"foo\": {\n    \"bar1\": \"1\",\n    \"bar2\": \"2\",\n    \"bar3\": {\n      \"doo1\": \"3\",\n      \"doo2\": \"4\"\n    }\n  }\n}",
      "Convert keys to paths, and put the values in their original places using [`setpath`](https://stedolan.github.io/jq/manual/#setpath(PATHS;VALUE)).",
      ". as $in | reduce keys_unsorted[] as $k ({}; setpath($k / \".\"; $in[$k]))"
    ],
    "utterance": "Convert a dictionary with dot-separated keys into a nested dictionary structure matching the key paths.",
    "expressions": [
      ". as $in | reduce keys_unsorted[] as $k ({}; setpath($k / \".\"; $in[$k]))"
    ],
    "data": [
      {
        "input": {
          "foo.bar1": "1",
          "foo.bar2": "2",
          "foo.bar3.doo1": "3",
          "foo.bar3.doo2": "4"
        },
        "output": {
          "foo": {
            "bar1": "1",
            "bar2": "2",
            "bar3": {
              "doo1": "3",
              "doo2": "4"
            }
          }
        }
      }
    ],
    "identifier": 66041386
  },
  {
    "context": [
      "I want to add all items from File 2 to the .data.items list in File 1.",
      "jq --argfile extra 2.json '.data.items += $extra' 1.json"
    ],
    "utterance": "Append all elements from the second file's array to the items list under data in the first file.",
    "expressions": [
      "jq --argfile extra 2.json '.data.items += $extra' 1.json"
    ],
    "data": [
      {
        "input": {
          "file1": {
            "data": {
              "items": []
            }
          },
          "file2": [
            {
              "name": "first name",
              "path": [
                {
                  "matcher": "exact"
                }
              ]
            },
            {
              "name": "second name",
              "path": [
                {
                  "matcher": "partial"
                }
              ]
            }
          ]
        },
        "output": {
          "data": {
            "items": [
              {
                "name": "first name",
                "path": [
                  {
                    "matcher": "exact"
                  }
                ]
              },
              {
                "name": "second name",
                "path": [
                  {
                    "matcher": "partial"
                  }
                ]
              }
            ]
          }
        }
      }
    ],
    "identifier": 66043938
  },
  {
    "context": [
      "I would like to know how I can iterate over an object to print out the name of each subnet and its cidr range in the subnets object.",
      "Essentially the **desired OUTPUT** should look something like this:\n{\n    \"name\": \"asdf1\",\n    \"cidr\": \"10.....\"\n},\n{\n    \"name\": \"asdf2\",\n    \"cidr\": \"10.....\"\n}\n//...and so forth",
      "Sample INPUT:",
      "jq '.vnet_spoke_object.subnets | to_entries[].value | { name, cidr }'",
      "jq '.vnet_spoke_object.subnets | to_entries | map(.value | { name, cidr })'"
    ],
    "utterance": "Return each subnet's name and cidr range from the subnets object within vnet_spoke_object.",
    "expressions": [
      ".vnet_spoke_object.subnets | to_entries[].value | { name, cidr }",
      ".vnet_spoke_object.subnets | to_entries | map(.value | { name, cidr })"
    ],
    "data": [
      {
        "input": {
          "route_tables": {
            "asdf": {
              "disable_bgp_route_propagation": true,
              "name": "az_afw",
              "resource_group_name": "vnet-spoke",
              "route_entries": {
                "re1": {
                  "name": "rt-rfc-10-8",
                  "next_hop_in_ip_address": "10.0.0.0",
                  "next_hop_type": "VirtualAppliance",
                  "prefix": "10.0.0.0/8"
                },
                "re2": {
                  "name": "rt-rfc-172-12",
                  "next_hop_in_ip_address": "10.0.0.0",
                  "next_hop_type": "VirtualAppliance",
                  "prefix": "172.16.0.0/12"
                }
              }
            }
          },
          "vnet_peering_settings": {
            "peer1": {
              "peer_to_source": {
                "allow_forwarded_traffic": true,
                "allow_gateway_transit": false,
                "allow_virtual_network_access": true,
                "use_remote_gateways": true
              },
              "source_to_peer": {
                "allow_forwarded_traffic": true,
                "allow_gateway_transit": true,
                "allow_virtual_network_access": true,
                "use_remote_gateways": false
              }
            }
          },
          "vnet_spoke_object": {
            "specialsubnets": {},
            "subnets": {
              "objectAsdf1": {
                "cidr": "10.0.0.1/24",
                "enforce_private_link_endpoint_network_policies": false,
                "enforce_private_link_service_network_policies": false,
                "name": "asdf1",
                "nsg_creation": true,
                "nsg_inbound": [],
                "nsg_outbound": [],
                "route": null,
                "service_endpoints": []
              },
              "objectAsdf2": {
                "cidr": "10.0.0.1/24",
                "enforce_private_link_endpoint_network_policies": false,
                "enforce_private_link_service_network_policies": false,
                "name": "asdf2",
                "nsg_creation": true,
                "nsg_inbound": [],
                "nsg_outbound": [],
                "route": "asdf",
                "service_endpoints": [
                  "Microsoft.EventHub"
                ]
              },
              "objectAsdf3": {
                "cidr": "10.0.0.1/24",
                "enforce_private_link_endpoint_network_policies": false,
                "enforce_private_link_service_network_policies": false,
                "name": "asdf3",
                "nsg_creation": true,
                "nsg_inbound": [],
                "nsg_outbound": [],
                "route": "asdf",
                "service_endpoints": []
              },
              "objectAsdf4": {
                "cidr": "10.0.0.1/24",
                "enforce_private_link_endpoint_network_policies": false,
                "enforce_private_link_service_network_policies": false,
                "name": "asdf4",
                "nsg_creation": true,
                "nsg_inbound": [],
                "nsg_outbound": [],
                "route": "asdf",
                "service_endpoints": []
              }
            },
            "vnet": {
              "address_space": [
                "10.0.0.0/16"
              ],
              "ddos_id": "placeholder",
              "dns": [
                "10.0.0.1",
                "10.0.0.1"
              ],
              "enable_ddos_std": false,
              "name": "asdf"
            }
          }
        },
        "output": [
          {
            "name": "asdf1",
            "cidr": "10.0.0.1/24"
          },
          {
            "name": "asdf2",
            "cidr": "10.0.0.1/24"
          },
          {
            "name": "asdf3",
            "cidr": "10.0.0.1/24"
          },
          {
            "name": "asdf4",
            "cidr": "10.0.0.1/24"
          }
        ]
      }
    ],
    "identifier": 66023723
  },
  {
    "context": [
      "how can i get the same result without **duplicate** the part : \nselect(.location==\"Stockholm\") | .name \nhow can i reuse the result of **newname** feild ?",
      "You are filtering multiple times during object construction. You could filter first and then do the construction on the filtered list eg.\n\njq\nmap(select(.location==\"Stockholm\")) \n  | map({newname: .name, contains_w: (.name | startswith(\"W\"))})"
    ],
    "utterance": "Return, for each object where location equals Stockholm, both the name and whether the name starts with W, avoiding repeating the location==Stockholm condition.",
    "expressions": [
      "map(select(.location==\"Stockholm\")) | map({newname: .name, contains_w: (.name | startswith(\"W\"))})"
    ],
    "data": [
      {
        "input": {
          "FOO": {
            "name": "Donald",
            "location": "Stockholm"
          },
          "BAR": {
            "name": "Walt",
            "location": "Stockholm"
          },
          "BAZ": {
            "name": "Jack",
            "location": "Whereever"
          }
        },
        "output": [
          {
            "newname": "Donald",
            "contains_w": false
          },
          {
            "newname": "Walt",
            "contains_w": true
          }
        ]
      }
    ],
    "identifier": 66044249
  },
  {
    "context": [
      "I want to merge the not-null part of b.json into a.json",
      "Expected result:",
      "{\r\n\t\"config\":\r\n\t{\r\n\t\t\"config1\":\r\n\t\t{\r\n\t\t\t\"config11\":\r\n\t\t\t{\r\n\t\t\t\t\"apple\":\"apple\",\r\n\t\t\t\t\"orange\":\"orange\",\r\n\t\t\t\t\"lemon\":[\r\n\t\t\t\t\t\"lemon4\",\r\n\t\t\t\t\t\"lemon5\",\r\n\t\t\t\t\t\"lemon6\"\r\n\t\t\t\t],\r\n\t\t\t\t\"pear\":\"pear\"\r\n\t\t\t}\r\n\t\t},\r\n\t\t\"config2\":\r\n\t\t{\r\n\t\t\t\"config21\":\"hey\",\r\n\t\t\t\"config22\":\"goodbye\"\r\n\t\t}\r\n\t}\r\n}",
      "The key to a simple solution here is using `paths`, `getpath`, and `setpath`, e.g. like so:",
      "jq -f program.jq --argfile b b.json a.json",
      "program.jq",
      "reduce ($b | paths(scalars)) as $p (. ;\n  ($b|getpath($p)) as $v\n  | if $v != null then setpath($p; $v) else . end)",
      "deepmerge.jq:",
      "def deepmerge(a;b):\n    reduce b[] as $item (a; \n        reduce ($item | keys_unsorted[]) as $key (.; \n            $item[$key] as $val | ($val | type) as $type | .[$key] = if ($type == \"object\") then\n            deepmerge({}; [if .[$key] == null then {} else .[$key] end, $val])\n            elif ($type == \"null\") then\n            .[$key]\n            else\n            $val\n            end)\n        );   \n    deepmerge({}; .)",
      "jq -f deepmerge.jq -s aa.json bb.json",
      "it works"
    ],
    "utterance": "Merge two files such that for each path, use the value from the second file only if it is not null; otherwise, keep the value from the first file.",
    "expressions": [
      "reduce ($b | paths(scalars)) as $p (. ;\n  ($b|getpath($p)) as $v\n  | if $v != null then setpath($p; $v) else . end)",
      "def deepmerge(a;b):\n    reduce b[] as $item (a; \n        reduce ($item | keys_unsorted[]) as $key (.; \n            $item[$key] as $val | ($val | type) as $type | .[$key] = if ($type == \"object\") then\n            deepmerge({}; [if .[$key] == null then {} else .[$key] end, $val])\n            elif ($type == \"null\") then\n            .[$key]\n            else\n            $val\n            end)\n        );   \n    deepmerge({}; .)"
    ],
    "data": [
      {
        "input": {
          "a.json": {
            "config": {
              "config1": {
                "config11": {
                  "apple": "apple",
                  "orange": "orange",
                  "lemon": [
                    "lemon1",
                    "lemon2",
                    "lemon3"
                  ],
                  "pear": "pear"
                }
              },
              "config2": {
                "config21": "hello",
                "config22": "goodbye"
              }
            }
          },
          "b.json": {
            "config": {
              "config1": {
                "config11": {
                  "apple": null,
                  "orange": null,
                  "lemon": [
                    "lemon4",
                    "lemon5",
                    "lemon6"
                  ],
                  "pear": null
                }
              },
              "config2": {
                "config21": "hey",
                "config22": null
              }
            }
          }
        },
        "output": {
          "config": {
            "config1": {
              "config11": {
                "apple": "apple",
                "orange": "orange",
                "lemon": [
                  "lemon4",
                  "lemon5",
                  "lemon6"
                ],
                "pear": "pear"
              }
            },
            "config2": {
              "config21": "hey",
              "config22": "goodbye"
            }
          }
        }
      }
    ],
    "identifier": 66024299
  },
  {
    "context": [
      "I want to use jq to get the following result in csv format:",
      "Country, State, Name, Address",
      "USA, TX, Name1, SomeAdress1",
      "USA, FL, Name2, SomeAdress2",
      "USA, FL, Name3, SomeAdress3",
      "USA, CA, Name4, SomeAdress4",
      "You can store root object in a variable, and then expand the Employees arrays:",
      "$ jq -r '. as $root | .Employees[]|[$root.Country, $root.State, .Name, .address] | @csv'",
      "You need to generate a separate array for each employee.",
      "[.Country, .State] + (.Employees[] | [.Name, .address]) | @csv",
      "Here\u2019s another option to add to the answers you already have:",
      "jq -r '.Employee=.Employees[]|[.Country,.State,.Employee.Name,.Employee.address]|@csv'",
      "jq -r '.Employees[] as $e|[.Country,.State,$e.Name,$e.address]|@csv'"
    ],
    "utterance": "Produce one CSV row per employee, including their name and address along with the country and state.",
    "expressions": [
      ". as $root | .Employees[]|[$root.Country, $root.State, .Name, .address] | @csv",
      "[.Country, .State] + (.Employees[] | [.Name, .address]) | @csv",
      ".Employee=.Employees[]|[.Country,.State,.Employee.Name,.Employee.address]|@csv",
      ".Employees[] as $e|[.Country,.State,$e.Name,$e.address]|@csv"
    ],
    "data": [
      {
        "input": [
          {
            "Country": "USA",
            "State": "TX",
            "Employees": [
              {
                "Name": "Name1",
                "address": "SomeAdress1"
              }
            ]
          },
          {
            "Country": "USA",
            "State": "FL",
            "Employees": [
              {
                "Name": "Name2",
                "address": "SomeAdress2"
              },
              {
                "Name": "Name3",
                "address": "SomeAdress3"
              }
            ]
          },
          {
            "Country": "USA",
            "State": "CA",
            "Employees": [
              {
                "Name": "Name4",
                "address": "SomeAdress4"
              }
            ]
          }
        ],
        "output": [
          "\"USA\",\"TX\",\"Name1\",\"SomeAdress1\"",
          "\"USA\",\"FL\",\"Name2\",\"SomeAdress2\"",
          "\"USA\",\"FL\",\"Name3\",\"SomeAdress3\"",
          "\"USA\",\"CA\",\"Name4\",\"SomeAdress4\""
        ]
      }
    ],
    "identifier": 66025003
  },
  {
    "identifier": 66073927
  },
  {
    "context": [
      "This is the input:",
      "[{\"name\": \"book1\",\"id\": 18789,\"locations\": [{\"state\": \"mystate\",\"phone\": 8877887700}, {\"state\": \"mystate1\",\"phone\": 8877887701}]},{\"name\": \"book2\",\"id\": 18781,\"locations\": [{\"state\": \"mystate3\",\"phone\": 8877887711}, {\"state\": \"mystate4\",\"phone\": 8877887702}]}]",
      "And this is the expected output:",
      "{\n\t\"name\": [\"book1\", \"book2\"],\n\t\"id\": [\"18789\", \"18781\"],\n\t\"states\": [\n\t\t[\"mystate\", \"mystate\"],\n\t\t[\"mystate3\", \"mystate4\"]\n\t]\n}",
      "With JQ it'd be easier than that.\n``` none\n{\n  name:   map(.name),\n  id:     map(.id),\n  states: map(.locations | map(.state))\n}\n```"
    ],
    "utterance": "Produce an object with 'name' and 'id' arrays holding the top-level name and id values, and a 'states' array holding arrays of the state values from each object's locations.",
    "expressions": [
      "{ name: map(.name), id: map(.id), states: map(.locations | map(.state)) }"
    ],
    "data": [
      {
        "input": [
          {
            "name": "book1",
            "id": 18789,
            "locations": [
              {
                "state": "mystate",
                "phone": 8877887700
              },
              {
                "state": "mystate1",
                "phone": 8877887701
              }
            ]
          },
          {
            "name": "book2",
            "id": 18781,
            "locations": [
              {
                "state": "mystate3",
                "phone": 8877887711
              },
              {
                "state": "mystate4",
                "phone": 8877887702
              }
            ]
          }
        ],
        "output": {
          "name": [
            "book1",
            "book2"
          ],
          "id": [
            18789,
            18781
          ],
          "states": [
            [
              "mystate",
              "mystate1"
            ],
            [
              "mystate3",
              "mystate4"
            ]
          ]
        }
      }
    ],
    "identifier": 66047747
  },
  {
    "context": [
      "But its exporting all the keys. Need help in exporting few keys out of many keys.",
      "[ \"ip_prefix\", \"region\", \"service\" ] as $fields | .prefixes | ( $fields, ( .[] | [ .[ $fields[] ] ] ) ) | @tsv",
      ".prefixes[] | [.ip_prefix,.region,.service] | @csv"
    ],
    "utterance": "Output only the ip_prefix, region, and service fields from the prefixes array as a CSV or TSV table.",
    "expressions": [
      "[ \"ip_prefix\", \"region\", \"service\" ] as $fields | .prefixes | ( $fields, ( .[] | [ .[ $fields[] ] ] ) ) | @tsv",
      ".prefixes[] | [.ip_prefix,.region,.service] | @csv",
      "jq -r --argjson whitelist '[\"ip_prefix\",\"region\",\"service\"]' '.prefixes[] | [ .[$whitelist[]] ] | @csv'"
    ],
    "data": [
      {
        "input": {
          "syncToken": "1612442658",
          "createDate": "2021-02-04-12-44-18",
          "prefixes": [
            {
              "ip_prefix": "3.5.140.0/22",
              "region": "ap-northeast-2",
              "service": "AMAZON",
              "network_border_group": "ap-northeast-2"
            },
            {
              "ip_prefix": "35.180.0.0/16",
              "region": "eu-west-3",
              "service": "AMAZON",
              "network_border_group": "eu-west-3"
            },
            {
              "ip_prefix": "52.93.178.234/32",
              "region": "us-west-1",
              "service": "AMAZON",
              "network_border_group": "us-west-1"
            }
          ]
        },
        "output": [
          [
            "ip_prefix",
            "region",
            "service"
          ],
          [
            "3.5.140.0/22",
            "ap-northeast-2",
            "AMAZON"
          ],
          [
            "35.180.0.0/16",
            "eu-west-3",
            "AMAZON"
          ],
          [
            "52.93.178.234/32",
            "us-west-1",
            "AMAZON"
          ]
        ]
      }
    ],
    "identifier": 66050102
  },
  {
    "context": [
      "I want to convert it to the below json lines file:\n\n```\n{\"dog\":{\"breed_1\":12,\"breed_2\":20}}\n{\"cat\":{\"breed_1\":6,\"breed_2\":8}}\n```\n\nNotice, how every key value in the original JSON is now on a single line.",
      "I tried, `cat some_file.json | jq '.[]' -c > lines_file.jsonl` and it returned\n\n```\n{\"breed_1\": 12, \"breed_2\": 20}\n{\"breed_1\": 6, \"breed_2\": 8}\n```\n\nThe `dog` and `cat` key vanish.",
      "Here's one possibility:\n\n    jq -c 'keys_unsorted[] as $k | {($k): .[$k]}'"
    ],
    "utterance": "For each top-level entry, emit a line containing the key paired with its object value, preserving the key.",
    "expressions": [
      "keys_unsorted[] as $k | {($k): .[$k]}"
    ],
    "data": [
      {
        "input": {
          "dog": {
            "breed_1": 12,
            "breed_2": 20
          },
          "cat": {
            "breed_1": 6,
            "breed_2": 8
          }
        },
        "output": [
          {
            "dog": {
              "breed_1": 12,
              "breed_2": 20
            }
          },
          {
            "cat": {
              "breed_1": 6,
              "breed_2": 8
            }
          }
        ]
      }
    ],
    "identifier": 66070280
  },
  {
    "context": [
      "With `jq '[].name, [].author.email' foo.json`\n\nI get the list of all names, and the list of all emails. However, they do not display in an alternating format, with one name following each email",
      "What\u2019s the correct notation/syntax for this?",
      "One iteration is what\u2019s needed here:\n```\n.[] | (.name, .author.email)\n```"
    ],
    "utterance": "Output the name and author email for each object as alternating values in the result list, so that each name is immediately followed by its corresponding email.",
    "expressions": [
      ".[] | (.name, .author.email)"
    ],
    "data": [
      {
        "input": [
          {
            "id": "1",
            "name": "Hello",
            "active": true,
            "author": {
              "firstName": "Jane",
              "lastName": "Smith",
              "email": "hello@example.com"
            }
          },
          {
            "id": "2",
            "name": "World",
            "active": true,
            "author": {
              "firstName": "John",
              "lastName": "Doe",
              "email": "world@example.com"
            }
          }
        ],
        "output": [
          "Hello",
          "hello@example.com",
          "World",
          "world@example.com"
        ]
      }
    ],
    "identifier": 66071313
  },
  {
    "context": [
      "I have a json file in the following format:\n\n```\n{\n    \"foo\": {\n        \"type\": \"string\",\n        \"value\": \"hello\"\n    },\n    \"bar\": {\n        \"type\": \"string\",\n        \"value\": \"goodbye\"\n    }\n}\n```",
      "I want to transform it to:\n```\n{\n\"foo\": \"hello\",\n\"bar\": \"goodbye\"\n}\n```",
      "jq 'map_values(.value)' file.json",
      "Output:\n\n    {\n      \"foo\": \"hello\",\n      \"bar\": \"goodbye\"\n    }"
    ],
    "utterance": "Extract the 'value' property for each top-level key and produce an object with the same keys mapping directly to those values.",
    "expressions": [
      "map_values(.value)"
    ],
    "data": [
      {
        "input": {
          "foo": {
            "type": "string",
            "value": "hello"
          },
          "bar": {
            "type": "string",
            "value": "goodbye"
          }
        },
        "output": {
          "foo": "hello",
          "bar": "goodbye"
        }
      }
    ],
    "identifier": 66071801
  },
  {
    "context": [
      "- Search the keys actual name value for a string or set of strings",
      "- search using case insensitive values",
      "- return the object(s) containing the values",
      "jq 'select( keys[]| ascii_downcase |contains( \"pw\",\"password\"))'",
      "select( any(keys_unsorted[] | ascii_downcase;\n            IN(\"password\", \"pw\", \"pa$$word\") ) )"
    ],
    "utterance": "Find objects containing at least one key whose name matches any of a list of strings (such as 'password', 'pw', 'pa$$word'), matching case-insensitively.",
    "expressions": [
      "select(any(keys_unsorted[] | ascii_downcase; IN(\"password\", \"pw\", \"pa$$word\")))",
      "select(keys[] | ascii_downcase | contains(\"pw\", \"password\"))"
    ],
    "data": [
      {
        "input": [
          {
            "PassworD": "dashnd8",
            "Name": "Katy"
          },
          {
            "PasSWOrd": "DJNAS98das98",
            "Name": "Paulo"
          },
          {
            "Pa$$word": "H(AD*Sn",
            "Name": "Crissy"
          },
          {
            "PW": "nA(*DS",
            "Name": "Jamel"
          },
          {
            "pW": "0d9asm0i",
            "Name": "Denny"
          }
        ],
        "output": [
          {
            "PassworD": "dashnd8",
            "Name": "Katy"
          },
          {
            "PasSWOrd": "DJNAS98das98",
            "Name": "Paulo"
          },
          {
            "Pa$$word": "H(AD*Sn",
            "Name": "Crissy"
          },
          {
            "PW": "nA(*DS",
            "Name": "Jamel"
          },
          {
            "pW": "0d9asm0i",
            "Name": "Denny"
          }
        ]
      },
      {
        "input": [
          {
            "Password": "PW",
            "Name": "Katy"
          },
          {
            "Password": "pW",
            "Name": "Paulo"
          },
          {
            "Password": "pw",
            "Name": "Crissy"
          },
          {
            "Password": "passWorD",
            "Name": "Jamel"
          },
          {
            "Password": "PAssword",
            "Name": "Denny"
          }
        ],
        "output": [
          {
            "Password": "PW",
            "Name": "Katy"
          },
          {
            "Password": "pW",
            "Name": "Paulo"
          },
          {
            "Password": "pw",
            "Name": "Crissy"
          },
          {
            "Password": "passWorD",
            "Name": "Jamel"
          },
          {
            "Password": "PAssword",
            "Name": "Denny"
          }
        ]
      }
    ],
    "identifier": 66055077
  },
  {
    "context": [
      "If I do all in one line it gives me an error:",
      "call_api -s \"job=work_1*&status=Executing\"  | $PATH_API/jq '.statuses[].name // empty' --raw-output",
      "parse error: Unfinished string at EOF at line 2301, column 61",
      "But if I redirect the api's output to a file and then apply jq to that file it doesn't raise any error:",
      "$PATH_API/jq '.statuses[].name // empty' --raw-output /tmp/kk",
      "work_1_002103ALLGDC",
      "work_1_000049EVEFIN",
      "work_1_002038ALF003",
      "Is it possible to fix it to can achieve it in one line?",
      "There should be no inherent difference in jq's behavior.",
      "cat fred.json | jq -r '.[]'"
    ],
    "utterance": "Extract all status names from the API output where the command is executed in a single pipeline.",
    "expressions": [
      ".statuses[].name // empty",
      "-r '.statuses[].name // empty'",
      "jq -r '.statuses[].name // empty'"
    ],
    "identifier": 66116539
  },
  {
    "context": [
      "I have a JSON document holding configurations with macros.  I need to expand macros that reference other elements.  For simplicity, consider this input document.",
      "map(. as $lookup | map_values(gsub(\"\\\\{(?<found_key>.*?)\\\\}\"; $lookup[.found_key])))",
      "You will note that it uses a named group `(?<found_key>.*?)` in the regular expression (see oniguruma's [named group][1])"
    ],
    "utterance": "Expand macros in each object that reference sibling values using the format {fieldname}.",
    "expressions": [
      "map(. as $lookup | map_values(gsub(\"\\{(?<found_key>.*?)\\}\"; $lookup[.found_key])))"
    ],
    "data": [
      {
        "input": [
          {
            "first": "Tim",
            "Full": "{first} {last}",
            "last": "Smith"
          },
          {
            "first": "Jane",
            "Full": "{first} {last}",
            "last": "Doe"
          }
        ],
        "output": [
          {
            "first": "Tim",
            "Full": "Tim Smith",
            "last": "Smith"
          },
          {
            "first": "Jane",
            "Full": "Jane Doe",
            "last": "Doe"
          }
        ]
      }
    ],
    "identifier": 66104360
  },
  {
    "context": [
      "What is the version for 'my_comp_2' which in the example should give me '1.0'",
      "$ jq -r --arg name my_comp_2 '\n  .[]\n  | select(.name == $name)\n  | .desiredVersions[].name\n' file.json"
    ],
    "utterance": "Return the value of 'name' inside 'desiredVersions' for the object whose 'name' is 'my_comp_2'.",
    "expressions": [
      ".[] | select(.name == $name) | .desiredVersions[].name"
    ],
    "data": [
      {
        "input": [
          {
            "name": "my_comp_1",
            "desiredVersions": []
          },
          {
            "name": "my_comp_2",
            "desiredVersions": [
              {
                "name": "1.0",
                "component": {
                  "name": "my_comp_2"
                }
              }
            ]
          },
          {
            "name": "my_comp_3",
            "desiredVersions": [
              {
                "name": "1.1",
                "component": {
                  "name": "my_comp_3"
                }
              }
            ]
          }
        ],
        "output": "1.0"
      }
    ],
    "identifier": 66119475
  },
  {
    "context": [
      "I'm looking to use jq to automatically resolve any field which contains json as json, example:",
      "Input",
      "    {",
      "      \"guaranteedPrizes\": \"[]\",",
      "    }",
      "Output",
      "    {",
      "      \"guaranteedPrizes\": [],",
      "    }",
      "For a generic solution, you might wish to consider `walk/1`, and for efficiency, avoid calling `fromjson` redundantly:",
      "    walk(if type == \"string\"\n         then . as $x | try fromjson catch $x\n         else . end)",
      "If you want to go off the \u201cdeep end\u201d and try evaluating fromjson recursively:",
      "def deep:\n  walk(if type == \"string\"          \n           then . as $x \n           | try (fromjson | deep)\n             catch $x     \n           else . end);\ndeep"
    ],
    "utterance": "Convert all fields containing string values that are valid JSON into their native types, including arrays and objects, recursively.",
    "expressions": [
      "walk(if type == \"string\" then . as $x | try fromjson catch $x else . end)",
      "def deep: walk(if type == \"string\" then . as $x | try (fromjson | deep) catch $x else . end); deep"
    ],
    "data": [
      {
        "input": {
          "guaranteedPrizes": "[]"
        },
        "output": {
          "guaranteedPrizes": []
        }
      }
    ],
    "identifier": 66101660
  },
  {
    "context": [
      "But desired result is as below:-\nfruits,mango,1kg\nfruits,kiwi,2pc\nfruits,apple,2kg\nfruits,banana,6pc\nvegetables,potato,3kg\nvegetables,onion,2kg\nvegetables,tomato,2kg\ndryfruits,almonds,2kg\ndryfruits,cachewnut,1kg\ndryfruits,walnut,1.5kg\npulses,Blackgram,1kg\npulses,chickpeas,2kg\npulses,lentils,1.5kg",
      "To achieve the desired result, you can simply invoke jq once using thie following jq program:\n\n.grocery[]\n| [.type] + ( .items[] | [.name, .quantity])\n| join (\",\")"
    ],
    "utterance": "Output each item's category, name, and quantity as a comma-separated line for all items, e.g. 'fruits,mango,1kg'.",
    "expressions": [
      ".grocery[] | [.type] + (.items[] | [.name, .quantity]) | join(\",\")"
    ],
    "data": [
      {
        "input": {
          "grocery": [
            {
              "type": "fruits",
              "items": [
                {
                  "name": "mango",
                  "quantity": "1kg"
                },
                {
                  "name": "kiwi",
                  "quantity": "2pc"
                },
                {
                  "name": "apple",
                  "quantity": "2kg"
                },
                {
                  "name": "banana",
                  "quantity": "6pc"
                }
              ]
            },
            {
              "type": "vegetables",
              "items": [
                {
                  "name": "potato",
                  "quantity": "3kg"
                },
                {
                  "name": "onion",
                  "quantity": "2kg"
                },
                {
                  "name": "tomato",
                  "quantity": "2kg"
                }
              ]
            },
            {
              "type": "dryfruits",
              "items": [
                {
                  "name": "almonds",
                  "quantity": "2kg"
                },
                {
                  "name": "cachewnut",
                  "quantity": "1kg"
                },
                {
                  "name": "walnut",
                  "quantity": "1.5kg"
                }
              ]
            },
            {
              "type": "pulses",
              "items": [
                {
                  "name": "Blackgram",
                  "quantity": "1kg"
                },
                {
                  "name": "chickpeas",
                  "quantity": "2kg"
                },
                {
                  "name": "lentils",
                  "quantity": "1.5kg"
                }
              ]
            }
          ]
        },
        "output": [
          "fruits,mango,1kg",
          "fruits,kiwi,2pc",
          "fruits,apple,2kg",
          "fruits,banana,6pc",
          "vegetables,potato,3kg",
          "vegetables,onion,2kg",
          "vegetables,tomato,2kg",
          "dryfruits,almonds,2kg",
          "dryfruits,cachewnut,1kg",
          "dryfruits,walnut,1.5kg",
          "pulses,Blackgram,1kg",
          "pulses,chickpeas,2kg",
          "pulses,lentils,1.5kg"
        ]
      }
    ],
    "identifier": 66100850
  },
  {
    "context": [
      "I want to replace a property for all the objects in the JSON files at the same time for a certain condition.",
      "For example, let's say that I want to replace all the rtsp values of the objects with identifier equal to \"cameraA\".",
      "jq 'if .identifier == \\\"cameraA\" then .rtsp=\\\"cameraX\" else . end' -c *.json"
    ],
    "utterance": "Replace rtsp property values with \"cameraX\" for objects where identifier is \"cameraA\" in multiple files.",
    "expressions": [
      "jq 'if .identifier == \"cameraA\" then .rtsp = \"cameraX\" else . end' file.json"
    ],
    "data": [
      {
        "input": {
          "identifier": "cameraA",
          "alias": "a",
          "rtsp": "192.168.1.1"
        },
        "output": {
          "identifier": "cameraA",
          "alias": "a",
          "rtsp": "cameraX"
        }
      },
      {
        "input": {
          "identifier": "cameraB",
          "alias": "b",
          "rtsp": "192.168.1.2"
        },
        "output": {
          "identifier": "cameraB",
          "alias": "b",
          "rtsp": "192.168.1.2"
        }
      }
    ],
    "identifier": 66120729
  },
  {
    "context": [
      "How can I transform it into something like:\r\n\r\n{\r\n   \"apple\": [42, 666],\r\n   \"pear\": [13],\r\n}\r\n\ngrouping the `bar`s by the `foo`s?",
      "You could use `group_by` and do the transformation after that, i.e. form the key with `.foo` and add all the `.bar`'s",
      "group_by(.foo)[] | { (.[0].foo): [.[].bar] }",
      "A simple and efficient solution would avoid `group_by`, the implementation of which currently entails a sorting operation:",
      "reduce .[] as $x ({}; .[$x.foo] += [$x.bar])"
    ],
    "utterance": "Group the values of 'bar' by the corresponding 'foo' values, creating an object where each key is a unique 'foo' and the value is a list of associated 'bar' values.",
    "expressions": [
      "group_by(.foo)[] | { (.[0].foo): [.[].bar] }",
      "reduce .[] as $x ({}; .[$x.foo] += [$x.bar])"
    ],
    "data": [
      {
        "input": [
          {
            "foo": "apple",
            "bar": 42
          },
          {
            "foo": "pear",
            "bar": 13
          },
          {
            "foo": "apple",
            "bar": 666
          }
        ],
        "output": {
          "apple": [
            42,
            666
          ],
          "pear": [
            13
          ]
        }
      }
    ],
    "identifier": 66124805
  },
  {
    "context": [
      "how can i use jq to convert json to csv file where \"0,1,5,6\" must be the columns and the values \u200b\u200bof \"0,1,5,6\" must respectively occupy each row of the csv file, like this:",
      "0,1,5,6",
      "52.51742935180664, 13.392845153808594, \"2021-02-09T13:15:15Z\", 20.754192352294922",
      "The following assumes the input consists of a stream of valid JSON objects along the lines shown in the question.",
      "If the relevant values of .id are known beforehand, then generating the header row is trivial, and a  solution implemented with flexibility in mind is as follows:",
      "def oneline:\n  .content.resources\n  | INDEX(.[]; .id) | map_values(.value);\n\ndef emit($keys):\n  [.[ $keys[] ]];\n  \n[0,1,5,6] as $keys\n| $keys,\n  (inputs | oneline | emit($keys))\n| join(\",\")"
    ],
    "utterance": "Extract resource values with ids 0, 1, 5, and 6 as CSV columns labeled 0,1,5,6; output each object's values in these columns as CSV rows.",
    "expressions": [
      "def oneline:\n  .content.resources\n  | INDEX(.[]; .id) | map_values(.value);\n\ndef emit($keys):\n  [.[ $keys[] ]];\n  \n[0,1,5,6] as $keys\n| $keys,\n  (inputs | oneline | emit($keys))\n| join(\",\")"
    ],
    "data": [
      {
        "input": {
          "status": "CONTENT",
          "valid": true,
          "success": true,
          "failure": false,
          "content": {
            "id": 0,
            "resources": [
              {
                "id": 0,
                "value": 52.51742935180664
              },
              {
                "id": 1,
                "value": 13.392845153808594
              },
              {
                "id": 5,
                "value": "2021-02-09T13:15:15Z"
              },
              {
                "id": 6,
                "value": 20.754192352294922
              }
            ]
          }
        },
        "output": "0,1,5,6\n52.51742935180664,13.392845153808594,\"2021-02-09T13:15:15Z\",20.754192352294922"
      }
    ],
    "identifier": 66120306
  },
  {
    "context": [
      "How to get values for the first two keys using jq in the same manner? I tried below",
      "# jq -r 'keys_unsorted[0:2] as $key | \"\\($key), \\(.[$key])\"' food.json",
      "jq: error (at food.json:9): Cannot index object with array",
      "Expected output:",
      "food_group, fruit",
      "glycemic_index, low",
      "To iterate over a hash array , you can use `to_entries` and that will transform to a array .",
      "jq -r 'to_entries[]| select(  ( .value | type ) == \"string\" ) | \"\\(.key), \\(.value)\" ' ",
      "You can use `to_entries`",
      "to_entries[] | select(.key==\"food_group\" or .key==\"glycemic_index\") | \"\\(.key), \\(.value)\""
    ],
    "utterance": "Return the keys and values of 'food_group' and 'glycemic_index', formatted as 'key, value', each on its own line.",
    "expressions": [
      "to_entries[] | select(.key==\"food_group\" or .key==\"glycemic_index\") | \"\\(.key), \\(.value)\"",
      "to_entries[]| select(  ( .value | type ) == \"string\" ) | \"\\(.key), \\(.value)\""
    ],
    "data": [
      {
        "input": {
          "food_group": "fruit",
          "glycemic_index": "low",
          "fruits": {
            "fruit_name": "apple",
            "size": "large",
            "color": "red"
          }
        },
        "output": "food_group, fruit\nglycemic_index, low"
      }
    ],
    "identifier": 66415016
  },
  {
    "context": [
      "Show the entire security group details (security group id, description)",
      "Only show security groups where IpPermissions.UserIdGroupPairs has a Value and where that value is not equal to the owner of the security group",
      "aws ec2 describe-security-groups --query \"SecurityGroups[?IpPermissions.UserIdGroupPairs[*].UserId != '`aws sts get-caller-identity --query 'Account' --output text`']\""
    ],
    "utterance": "List all security groups whose IpPermissions.UserIdGroupPairs contains a UserId not equal to the security group owner's account, displaying the group id and description.",
    "expressions": [
      ".SecurityGroups[] | select(.IpPermissions[].UserIdGroupPairs[]? | select(.UserId != $OWNER_ID)) | {GroupId, Description}"
    ],
    "identifier": 66140960
  },
  {
    "context": [
      "I am trying to access the servername based on the username here from a script with the jq as below:",
      "jq .servers.${AUTHOR}.server",
      "For authorname2 it is working fine and returning server app-dv-app02.",
      "But for author-name it is throwing error as below.",
      "+ jq .servers.author-name.server",
      "jq: error: name/0 is not defined at <top-level>, line 1:",
      ".servers.ppataky-unzer.server",
      "Could someone please help here to rectify the correct syntax of jq call."
    ],
    "utterance": "Access the 'server' field for the 'author-name' key within 'servers', where the key contains a dash.",
    "expressions": [
      ".servers[\"author-name\"].server"
    ],
    "data": [
      {
        "input": {
          "servers": {
            "author-name": {
              "server": "app-dv-app01"
            },
            "authorname2": {
              "server": "app-dv-app02"
            }
          }
        },
        "output": "app-dv-app01"
      }
    ],
    "identifier": 66175484
  },
  {
    "context": [
      "Intuitively I try  `jq '..|.v? | add'` and expect `9` but get an error:  ",
      "`add` expects an array, so you could wrap your stream up (`[..|.v?]`), or much better, define a stream-based version of `add`:",
      "def sigma(s): reduce s as $x (0; .+$x);",
      "sigma(.. | .v?)"
    ],
    "utterance": "Sum all values associated with the key 'v' at any depth in the data structure.",
    "expressions": [
      "[..|.v?] | add",
      "def sigma(s): reduce s as $x (0; .+$x); sigma(.. | .v?)"
    ],
    "data": [
      {
        "input": {
          "v": 0,
          "child": {
            "v": 2,
            "child": {
              "v": 3,
              "child": {
                "v": null
              }
            },
            "list": [
              {
                "v": 4
              }
            ]
          }
        },
        "output": 9
      }
    ],
    "identifier": 66177544
  },
  {
    "context": [
      "I have multiple json files and all have the same parent element. I want to merge all the child elements into one file with one parent element without duplicate keys(take only the last occurrence of a key into the final file).",
      "But how to do it for multiple files using jq?",
      "def star(s): reduce s as $x ({}; . * $x);",
      "jq -n '\n  def star(s): reduce s as $x ({}; . * $x);\n  star(inputs)\n' file*.json"
    ],
    "utterance": "Merge multiple files into one, combining objects under the same parent and keeping only the last occurrence of each child key.",
    "expressions": [
      "jq -n 'def star(s): reduce s as $x ({}; . * $x); star(inputs)' file*.json"
    ],
    "data": [
      {
        "input": [
          {
            "parent1": {
              "child1": {
                "prop1": "val1"
              },
              "child2": {
                "prop2": "val2"
              }
            }
          },
          {
            "parent1": {
              "child1": {
                "prop4": "val4"
              },
              "child3": {
                "prop3": "val3"
              }
            }
          }
        ],
        "output": {
          "parent1": {
            "child1": {
              "prop4": "val4"
            },
            "child2": {
              "prop2": "val2"
            },
            "child3": {
              "prop3": "val3"
            }
          }
        }
      }
    ],
    "identifier": 66177589
  },
  {
    "context": [
      "how can i get the *same result* without **duplicate** the part :",
      ".data | select(.answers != null) | .answers | map(.answer) | del(.[] | nulls)",
      "how can i reuse the result of `results` feild ?",
      "With a variable",
      "(.data | select(.answers != null) | .answers | map(.answer) | del(.[] | nulls)) as $data\n  | { \n    domain: .name, \n    results: $data,\n    includes: $data | map(match(\"rearch:(.*?)?[ \\\"\"]; \"ig\").captures[0].string) | unique\n    }",
      "Without a variable",
      "{ domain: .name, \n    results: (.data | select(.answers != null) | .answers | map(.answer) | del(.[] | nulls)) }\n  | .includes = (.results | map(match(\"rearch:(.*?)?[ \\\"\"]; \"ig\").captures[0].string) | unique)"
    ],
    "utterance": "Reuse the filtered list of answer values to build multiple fields without repeating the filtering logic.",
    "expressions": [
      "(.data | select(.answers != null) | .answers | map(.answer) | del(.[] | nulls)) as $data | { domain: .name, results: $data, includes: $data | map(match(\"rearch:(.*?)?[ \\\"\"]; \"ig\").captures[0].string) | unique }",
      "{ domain: .name, results: (.data | select(.answers != null) | .answers | map(.answer) | del(.[] | nulls)) } | .includes = (.results | map(match(\"rearch:(.*?)?[ \\\"\"]; \"ig\").captures[0].string) | unique)"
    ],
    "data": [
      {
        "input": {
          "name": "blabla.com",
          "data": {
            "answers": [
              {
                "answer": "dorem rearch:blble.k iyh"
              }
            ]
          }
        },
        "output": {
          "domain": "blabla.com",
          "results": [
            "dorem rearch:blble.k iyh"
          ],
          "includes": [
            "blble.k"
          ]
        }
      },
      {
        "input": {
          "name": "bla.com",
          "data": {
            "answers": [
              {
                "answer": "koa rearch:ble.m"
              },
              {
                "answer": "kl rearch:be.c lk"
              }
            ]
          }
        },
        "output": {
          "domain": "bla.com",
          "results": [
            "koa rearch:ble.m",
            "kl rearch:be.c lk"
          ],
          "includes": [
            "ble.m",
            "be.c"
          ]
        }
      }
    ],
    "identifier": 66135479
  },
  {
    "context": [
      "I need to use the csv filename as the json object name, read the csv to get the fieldnames from the header, and do a bit of re-mapping to move \"owner\" to a list (array?) name.",
      "So, take this:",
      "serverset1.csv",
      "location,category,ip,owner",
      "set1rack1,webserver,127.0.0.1,Customer1",
      "set1rack2,appserver,127.0.0.2,Customer1",
      "set1rack1,webserver,127.0.0.3,Customer2",
      "set1rack2,appserver,127.0.0.4,Customer2",
      "to this",
      "[",
      "   {",
      "      \"serverset1\":[",
      "         {",
      "            \"Customer1\":[",
      "               {",
      "                  \"location\":\"set1rack1\",",
      "                  \"category\":\"webserver\",",
      "                  \"address\":\"127.0.0.1\"",
      "               },",
      "               {",
      "                  \"location\":\"set1rack2\",",
      "                  \"category\":\"appserver\",",
      "                  \"address\":\"127.0.0.2\"",
      "               }",
      "            ],",
      "            \"Customer2\":[",
      "               {",
      "                  \"location\":\"set1rack1\",",
      "                  \"category\":\"webserver\",",
      "                  \"address\":\"127.0.0.3\"",
      "               },",
      "               {",
      "                  \"location\":\"set1rack2\",",
      "                  \"category\":\"appserver\",",
      "                  \"address\":\"127.0.0.4\"",
      "               }",
      "            ]",
      "         }",
      "      ]",
      "   }",
      "]",
      "jq -R '\n  reduce inputs as $in ({};\n   (input_filename | sub(\"[.]csv$\";\"\")) as $file\n   | ($in | [splits(\", *\")]) as $row\n   | {location: $row[0], category: $row[1], address: $row[2]} as $obj\n   | .[$file][$row[3]] += [$obj])\n| [ . ]\n' serverset1.csv"
    ],
    "utterance": "Convert a CSV file so that each row becomes an object with keys location, category, address, grouped by owner, under a top-level object named after the CSV filename (without .csv), and output as a single-element array.",
    "expressions": [
      "jq -R '\n  reduce inputs as $in ({};\n   (input_filename | sub(\"[.]csv$\";\"\")) as $file\n   | ($in | [splits(\", *\")]) as $row\n   | {location: $row[0], category: $row[1], address: $row[2]} as $obj\n   | .[$file][$row[3]] += [$obj])\n| [ . ]\n' serverset1.csv"
    ],
    "data": [
      {
        "input": "location,category,ip,owner\nset1rack1,webserver,127.0.0.1,Customer1\nset1rack2,appserver,127.0.0.2,Customer1\nset1rack1,webserver,127.0.0.3,Customer2\nset1rack2,appserver,127.0.0.4,Customer2\n",
        "output": [
          {
            "serverset1": [
              {
                "Customer1": [
                  {
                    "location": "set1rack1",
                    "category": "webserver",
                    "address": "127.0.0.1"
                  },
                  {
                    "location": "set1rack2",
                    "category": "appserver",
                    "address": "127.0.0.2"
                  }
                ],
                "Customer2": [
                  {
                    "location": "set1rack1",
                    "category": "webserver",
                    "address": "127.0.0.3"
                  },
                  {
                    "location": "set1rack2",
                    "category": "appserver",
                    "address": "127.0.0.4"
                  }
                ]
              }
            ]
          }
        ]
      }
    ],
    "identifier": 66130421
  },
  {
    "context": [
      "cat target.json | jq '.[] | select(.sex | endswith(\"female\")) |@csv'",
      "jq: error (at <stdin>:0): object ({\"sex\":...) cannot be csv-formatted, only array",
      "jq -r '\n      .[] \n      | select(.sex | endswith(\"female\")) \n      | to_entries\n      | map(.value) \n      | @csv \n    ' target.json",
      "jq -r '\n  (.[0]|keys_unsorted) as $keys\n  | $keys,\n    (.[] \n     | select(.sex | endswith(\"female\")) \n     | [.[ $keys[] ]])\n  | @csv \n' target.json"
    ],
    "utterance": "Output only rows where sex ends with \"female\" as CSV.",
    "expressions": [
      ".[] | select(.sex | endswith(\"female\")) | to_entries | map(.value) | @csv",
      "(.[0] | keys_unsorted) as $keys | $keys, (.[] | select(.sex | endswith(\"female\")) | [.[ $keys[] ]]) | @csv"
    ],
    "data": [
      {
        "input": [
          {
            "name": "Mike",
            "age": "15",
            "sex": "male"
          },
          {
            "name": "Dan",
            "age": "10",
            "sex": "male"
          },
          {
            "name": "Kasia",
            "age": "5",
            "sex": "female"
          }
        ],
        "output": [
          "\"Kasia\",\"5\",\"female\""
        ]
      }
    ],
    "identifier": 66182953
  },
  {
    "context": [
      "I want to replace a string in a json file.",
      "I'd like to have a change detection so the restart is only applied when needed.",
      "But during testing I found out that the hash even changes when just printing the file without any modification.",
      "You could check whether the new file is JSON-equal to the original file using jq's `==` operator.",
      "jq --arg platform \"MyPlatformName\" 'if .payload.platformName == $platform then . else .payload.platformName = $platform, (null|halt_error(99)) end' resources/commonProperties.json > /tmp/out.json",
      "This would result in returncode 99 if the file was edited",
      "If we re-run the tool on the modified file, no modification needs to be applied and we got rc = 0"
    ],
    "utterance": "Update payload.platformName to \"MyPlatformName\" only if it differs, and detect if any modification was actually made.",
    "expressions": [
      "jq --arg platform \"MyPlatformName\" 'if .payload.platformName == $platform then . else .payload.platformName = $platform, (null|halt_error(99)) end' resources/commonProperties.json > /tmp/out.json"
    ],
    "data": [
      {
        "input": {
          "payload": {
            "platformName": "OldPlatform"
          }
        },
        "output": {
          "payload": {
            "platformName": "MyPlatformName"
          }
        }
      },
      {
        "input": {
          "payload": {
            "platformName": "MyPlatformName"
          }
        },
        "output": {
          "payload": {
            "platformName": "MyPlatformName"
          }
        }
      }
    ],
    "identifier": 66197521
  },
  {
    "context": [
      "the extraction should not assume the field names are fixed to these specific ones, as other field names can be used in other similar files.",
      "The output should be a two-column TSV, with the field name as the first column and the field value as the second column.",
      "The following illustrates how to convert the array-oriented JSON produced by rb2json0.rb to a more object-oriented JSON, in a way that you can query for `update_info@ident` in a straightforward way.",
      "def objectify:\n  if type == \"array\"\n  then if length>=2 and (.[0]|type) == \"string\" and (.[1]|type) == \"array\"\n       then  {(.[0]): ( .[1:] | map(objectify)) | objectify }\n       elif length>=3 and .[0][0:1] == \"@\" and (.[1]|type) == \"string\"\n       then  { (.[1] + .[0]): ( .[2:] | map(objectify)) | objectify }\n       else map(objectify)\n       end\n  else . \n  end;",
      "objectify | .. | objects | .[\"update_info@ident\"]? // empty"
    ],
    "utterance": "Output key-value pairs found under update_info and register_options, with the field name and field value in two TSV columns, handling nonstandard JSON array structure and supporting arbitrary field names.",
    "expressions": [
      "def objectify:\n  if type == \"array\"\n  then if length>=2 and (.[0]|type) == \"string\" and (.[1]|type) == \"array\"\n       then  {(.[0]): ( .[1:] | map(objectify)) | objectify }\n       elif length>=3 and .[0][0:1] == \"@\" and (.[1]|type) == \"string\"\n       then  { (.[1] + .[0]): ( .[2:] | map(objectify)) | objectify }\n       else map(objectify)\n       end\n  else . \n  end;\n\nobjectify |..|objects|select(has(\"update_info\")).update_info[1][]|select(.[0]==\"bare_assoc_hash\")[1][]|. as $a|$a[1][1][1][1] as $k|$a[1][2][1][1] as $v| \"\u007f\"\n\n# (This is a partial, illustrative example; actual field extraction logic would need to traverse the objectified structure to extract all key-value field-name/value pairs from update_info and register_options, and output as TSV rows)"
    ],
    "identifier": 66192252
  },
  {
    "context": [
      "for row in $(echo \"${jsonFile}\" | jq -c '.fruits[]' );",
      "I am seeing below output:",
      "The row is  {\"name\":\"Orange\",\"colour\":\"Orange\"}",
      "The row is  {\"name\":\"Red",
      "The row is  Grapes\",\"colour\":\"Red\"}",
      "The expected output is:",
      "The row is  {\"name\":\"Orange\",\"colour\":\"Orange\"}",
      "The row is  {\"name\":\"Red Grapes\",\"colour\":\"Red\"}"
    ],
    "utterance": "Loop through each object in the array, safely handling values that contain spaces so that each object is processed correctly in the shell script.",
    "expressions": [
      "jq -c '.fruits[]' fruits.json | while read -r row; do echo \"The row is $row\"; done"
    ],
    "data": [
      {
        "input": {
          "fruits": [
            {
              "name": "Orange",
              "colour": "Orange"
            },
            {
              "name": "Red Grapes",
              "colour": "Red"
            }
          ]
        },
        "output": [
          "The row is {\"name\":\"Orange\",\"colour\":\"Orange\"}",
          "The row is {\"name\":\"Red Grapes\",\"colour\":\"Red\"}"
        ]
      }
    ],
    "identifier": 66205174
  },
  {
    "context": [
      "Let's try to select \"output\" where \"id\" is \"some-text\" - it works:",
      "$ ID=\"some-text\"\n$ cat test.json | jq -r --arg ID \"$ID\" '.[] | select(.id==$ID) | .output'\njq select works!",
      "Let's try to select \"output\" where \"id\" is \"123\" - it doesn't work:",
      "$ ID=\"123\"\n$ cat test.json | jq -r --arg ID \"$ID\" '.[] | select(.id==$ID) | .output'\n$ ",
      "Interestingly, \"select\" does work if I don't pass the variable via --arg:",
      "$ cat test.json | jq -r '.[] | select(.id==123) | .output'\njq select doesn't work :(",
      "You could also use [`tostring`] to convert the ID to a string so you can keep the existing format;",
      "$ ID=\"123\"\n$ cat test.json | jq -r --arg ID \"$ID\" '.[] | select(.id|tostring==$ID) | .output'\njq select doesn't work :(",
      "$ ID=\"some-text\"\n$ cat test.json | jq -r --arg ID \"$ID\" '.[] | select(.id|tostring==$ID) | .output'\njq select works!"
    ],
    "utterance": "Select the 'output' field for an object with a given id, where the id may be either a string or a number, and the search id is provided as a string variable.",
    "expressions": [
      ".[] | select(.id|tostring==$ID) | .output"
    ],
    "data": [
      {
        "input": [
          {
            "id": "some-text",
            "output": "jq select works!"
          },
          {
            "id": 123,
            "output": "jq select doesn't work :("
          }
        ],
        "output": "jq select doesn't work :("
      },
      {
        "input": [
          {
            "id": "some-text",
            "output": "jq select works!"
          },
          {
            "id": 123,
            "output": "jq select doesn't work :("
          }
        ],
        "output": "jq select works!"
      }
    ],
    "identifier": 66197271
  },
  {
    "context": [
      "I\u2019ve been trying to get the above into the following format\n\n    {\n      \"Servers\":{\n        \"1\": {\n          \"Name\": \"db-name\",\n          \"Port\": 3000,\n          \"Group\": \"Server Group 1\",\n          \"SSLMode\": \"prefer\",\n          \"MaintenanceDB\": \"postgres\"\n        },\n        \"2\": {\n          \"Name\": \"db-name\",\n          \"Port\": 5432,\n          \"Group\": \"Server Group 1\",\n          \"SSLMode\": \"prefer\",\n          \"MaintenanceDB\": \"postgres\"\n        }\n      }\n    }\n",
      "Given the stream of JSON objects shown in the question, the following jq filter will produce the desired output assuming the stream is somehow \"slurped\":",
      ".items\n| [to_entries[]\n   | {(.key+1|tostring): .value}\n   | map_values(\n      {Name:.metadata.name,\n       Port:.spec.ports[0].port,\n       Group: \"group name\",\n       SSLMode: \"prefer\",\n       MaintenanceDB: \"postgres\"}) ]\n| {Servers: add}"
    ],
    "utterance": "Transform an array of service objects, extracting specific fields and constants, and group them under a Servers object keyed by string indices starting from 1.",
    "expressions": [
      ". as $in | reduce range(0;length) as $i ({};.[$i+1|tostring] = $in[$i]) | {Servers: .}",
      ".items\n| [to_entries[]\n   | {(.key+1|tostring): .value}\n   | map_values(\n      {Name:.metadata.name,\n       Port:.spec.ports[0].port,\n       Group: \"group name\",\n       SSLMode: \"prefer\",\n       MaintenanceDB: \"postgres\"}) ]\n| {Servers: add}"
    ],
    "data": [
      {
        "input": [
          {
            "Name": "db-name",
            "Port": 3000,
            "Group": "group name",
            "SSLMode": "prefer",
            "MaintenanceDB": "postgres"
          },
          {
            "Name": "db-name",
            "Port": 5432,
            "Group": "group name",
            "SSLMode": "prefer",
            "MaintenanceDB": "postgres"
          }
        ],
        "output": {
          "Servers": {
            "1": {
              "Name": "db-name",
              "Port": 3000,
              "Group": "group name",
              "SSLMode": "prefer",
              "MaintenanceDB": "postgres"
            },
            "2": {
              "Name": "db-name",
              "Port": 5432,
              "Group": "group name",
              "SSLMode": "prefer",
              "MaintenanceDB": "postgres"
            }
          }
        }
      }
    ],
    "identifier": 66200213
  },
  {
    "context": [
      "echo \"${metrics}\" | ./jq -r \".names[]\" |",
      "Now The while-loop is not working, the output of `echo ${name}` is `metric1 metric12`.",
      "I tried to use this `IFS=' ' read -r ..` or this ` IFS= read -r ..` but still the variable `name` is not containing a single metric but all of them",
      "Instead of using `<<< $(...)` use: `< <(...)`",
      "done < <(echo \"${metrics}\" | ./jq -r \".names[]\")"
    ],
    "utterance": "Extract each element from the names array and output them one per line.",
    "expressions": [
      ".names[]",
      ".names[] | ."
    ],
    "data": [
      {
        "input": {
          "names": [
            "metric1",
            "metric12"
          ]
        },
        "output": [
          "metric1",
          "metric12"
        ]
      }
    ],
    "identifier": 66211414
  },
  {
    "context": [
      "The field \".text\" is the one that has the linebreaks I wish removed/replaced.",
      "Any tips regarding how to replace \"\\n\" from inside the field \",text\" ?",
      "For example, you could encode the newlines as pipe (\"|\") symbols using the jq filter:",
      "gsub(\"\\n\"; \"|\")",
      "Assuming \"text\" is a string-valued field which might contain embedded newlines, you would replace `.text` with (.text | gsub(\"\\n\"; \"|\"))",
      "If the value of `.text` might be null, then you will have to decide how you want to handle nulls.  (One possibility would be: `.text | tostring | gsub(\"\\n\";\"|\")`.)"
    ],
    "utterance": "Replace all newline characters in the decoded .text field with the pipe character (|).",
    "expressions": [
      ".text | gsub(\"\\n\"; \"|\")",
      ".text | tostring | gsub(\"\\n\"; \"|\")"
    ],
    "data": [
      {
        "input": {
          "receivedMessages": [
            {
              "ackId": "xxxxxx",
              "message": {
                "data": "eyJzZW5kZXJQaG9uZU51bWJlciI6ICIrOTk5OTk5OTk5OTk5OSIsIm1lc3NhZ2VJZCI6ICIyM2QyM2QyM2QzMmQiLCJzZW5kVGltZSI6ICIyMDIxLTAyLTAyVDIwOjAwOjAwLjAwMDAxIiwidGV4dCI6ICJYWFhYWCBYWFhYWFhYRSwgWFhYWFhYWC8gWHh4eHh4LlxuXG5YeHh4eHh4eHg6XG5cbjEgeHh4eCB4eCB4eHh4ICgyMDAgeHgpXG4yLDUgeHh4eHhcbjEgeHh4eCBcblxuWHh4eHh4IHh4eHh4eCJ9Cg==",
                "attributes": {
                  "product": "XXXX",
                  "project_number": "XXXXXX",
                  "message_type": "TEXT",
                  "type": "message"
                },
                "messageId": "234234234234234234",
                "publishTime": "2021-02-02T20:15:22.888Z"
              }
            }
          ]
        },
        "output": [
          "XXXX XXXXXXXE, XXXXXXX/ Xxxxxx.|",
          "|Xxxxxxxxx:|",
          "|1 xxxx xx xxxx (200 xx)|2,5 xxxxx|1 xxxx||Xxxxxx xxxxxx"
        ]
      }
    ],
    "identifier": 66142393
  },
  {
    "context": [
      "I want to get something like that:\n{\n  \"entries\": [\n  {\n    \"parent\": {\n      \"processid\": \"FOO11100\",\n      \"published\": \"2020-04-02T15:15:00Z\",\n      \"modified\": \"2020-12-24T16:15:00Z\",\n      \"access_authentication\": \"SINGLE\",\n      \"access_complexity\": \"LOW\",\n      \"access_vector\": \"NETWORK\"\n    },\n    \"childs\": [\n        {\n          \"processid\": \"FOO11100\",\n          \"childid\": 1,\n          \"type\": \"Application\",\n          \"name\": \"roxy\",\n          \"score\": \"1.8\",\n          \"lastupdate\": \"2020-12-24T16:15:00Z\"\n        },\n        {\n          \"processid\": \"FOO11100\",\n          \"childid\": 2,\n          \"type\": \"Application\",\n          \"name\": \"roxy\",\n          \"score\": \"1.9\",\n          \"lastupdate\": \"2020-12-24T16:15:00Z\"\n        },\n        {\n          \"processid\": \"FOO11100\",\n          \"childid\": 3,\n          \"type\": \"Operation\",\n          \"name\": \"ianu\",\n          \"score\": \"10.0\",\n          \"lastupdate\": \"2020-12-24T16:15:00Z\"\n        }\n      ]\n    }\n  ]\n}",
      "in the lower part I want to iterate over the elements within .available_product and access:\n- id and last-modified outside of the array for processid and lastupdate within the new object\n- the position of the element within the array for childid\n- the tokenized text part 3 to translate it (a=Application, o=Operation)",
      "The following works for your given input:\n\n. as { id: $processid, \"last-modified\": { \"$date\": $lastupdate } }\n| { a:\"Application\", o:\"Operation\" } as $types\n| {\n    entries: [\n        {\n            parent: {\n                $processid, \n                published: .Published.\"$date\", \n                modified: $lastupdate,\n                access_authentication: .access.authentication, \n                access_complexity: .access.complexity, \n                access_vector: .access.vector\n            },\n            children: .available_product\n                | map(\n                    split(\":\") as [$prefix, $name, $typeid, $name, $score]\n                    | $types[$typeid] as $type\n                    | { $processid, $type, $name, $score, $lastupdate }\n                )\n                | to_entries\n                | map({childid: (.key+1)} + .value)\n        }\n    ]\n}\n",
      "An alternative version which generates the same output could be:\n\n.id as $processid\n| .\"last-modified\".\"$date\" as $lastupdate\n| {\n    entries: [\n        {\n            parent: {\n                $processid, \n                published: .Published.\"$date\", \n                modified: $lastupdate,\n                access_authentication: .access.authentication, \n                access_complexity: .access.complexity, \n                access_vector: .access.vector\n            },\n            children: .available_product\n                | to_entries\n                | map(\n                    .value |= split(\":\")\n                    | {\n                        $processid,\n                        childid: (.key+1),\n                        type: { a:\"Application\", o:\"Operation\" }[.value[2]],\n                        name: .value[3],\n                        score: .value[4],\n                        $lastupdate\n                    }\n                )\n        }\n    ]\n}\n"
    ],
    "utterance": "Transform an object with an array property into a structure with 'entries', where each entry has a parent object and a list of children derived by splitting each array item and mapping fields, including translating a token to a type, extracting name and score, assigning position as childid, and including parent values.",
    "expressions": [
      ". as { id: $processid, \"last-modified\": { \"$date\": $lastupdate } }\n| { a:\"Application\", o:\"Operation\" } as $types\n| {\n    entries: [\n        {\n            parent: {\n                $processid, \n                published: .Published.\"$date\", \n                modified: $lastupdate,\n                access_authentication: .access.authentication, \n                access_complexity: .access.complexity, \n                access_vector: .access.vector\n            },\n            children: .available_product\n                | map(\n                    split(\":\") as [$prefix, $name, $typeid, $name, $score]\n                    | $types[$typeid] as $type\n                    | { $processid, $type, $name, $score, $lastupdate }\n                )\n                | to_entries\n                | map({childid: (.key+1)} + .value)\n        }\n    ]\n}",
      ".id as $processid\n| .\"last-modified\".\"$date\" as $lastupdate\n| {\n    entries: [\n        {\n            parent: {\n                $processid, \n                published: .Published.\"$date\", \n                modified: $lastupdate,\n                access_authentication: .access.authentication, \n                access_complexity: .access.complexity, \n                access_vector: .access.vector\n            },\n            children: .available_product\n                | to_entries\n                | map(\n                    .value |= split(\":\")\n                    | {\n                        $processid,\n                        childid: (.key+1),\n                        type: { a:\"Application\", o:\"Operation\" }[.value[2]],\n                        name: .value[3],\n                        score: .value[4],\n                        $lastupdate\n                    }\n                )\n        }\n    ]\n}"
    ],
    "data": [
      {
        "input": {
          "id": "FOO11100",
          "Published": {
            "$date": "2020-04-02T15:15:00Z"
          },
          "Modified": {
            "$date": "2020-12-24T16:15:00Z"
          },
          "last-modified": {
            "$date": "2020-12-24T16:15:00Z"
          },
          "access": {
            "authentication": "SINGLE",
            "complexity": "LOW",
            "vector": "NETWORK"
          },
          "available_product": [
            "custom:foo:a:roxy:1.8",
            "custom:foo:a:roxy:1.9",
            "custom:foo:o:ianu:10.0"
          ]
        },
        "output": {
          "entries": [
            {
              "parent": {
                "processid": "FOO11100",
                "published": "2020-04-02T15:15:00Z",
                "modified": "2020-12-24T16:15:00Z",
                "access_authentication": "SINGLE",
                "access_complexity": "LOW",
                "access_vector": "NETWORK"
              },
              "children": [
                {
                  "childid": 1,
                  "processid": "FOO11100",
                  "type": "Application",
                  "name": "roxy",
                  "score": "1.8",
                  "lastupdate": "2020-12-24T16:15:00Z"
                },
                {
                  "childid": 2,
                  "processid": "FOO11100",
                  "type": "Application",
                  "name": "roxy",
                  "score": "1.9",
                  "lastupdate": "2020-12-24T16:15:00Z"
                },
                {
                  "childid": 3,
                  "processid": "FOO11100",
                  "type": "Operation",
                  "name": "ianu",
                  "score": "10.0",
                  "lastupdate": "2020-12-24T16:15:00Z"
                }
              ]
            }
          ]
        }
      }
    ],
    "identifier": 66031869
  },
  {
    "context": [
      "The data (about 10x more rows than this example) is served from a proprietary HTTP server that I have no control over.",
      "I have created a data source that successfully pulls the data, but it ends up as as single row. As I understand, since the JSON object has no array at the root level, Druid sees these three objects as a single row.",
      "The closest I have gotten so far is with the following `flattenSpec`, but this only returns the first row from the JSON data (though the row is represented correctly).",
      "Try a filter like this and no flattening should be required:",
      "jq '.[] | {name,lastseen}'",
      "Using your input, this results in:",
      "{\n  \"name\": \"Temperature Sensor A\",\n  \"lastseen\": \"2021-02-15T05:02Z\"\n}",
      "{\n  \"name\": \"Temperature Sensor B\",\n  \"lastseen\": \"2021-02-15T05:01Z\"\n}",
      "{\n  \"name\": \"Temperature Sensor Backup\",\n  \"lastseen\": \"2021-02-15T05:00Z\"\n}"
    ],
    "utterance": "Extract each object's name and lastseen fields as separate objects from a root-level keyed object.",
    "expressions": [
      ".[] | {name, lastseen}"
    ],
    "data": [
      {
        "input": {
          "1": {
            "lastseen": "2021-02-15T05:02Z",
            "name": "Temperature Sensor A",
            "state": {
              "alert": "none",
              "level": 152,
              "on": true,
              "reachable": true
            }
          },
          "3": {
            "lastseen": "2021-02-15T05:01Z",
            "name": "Temperature Sensor B",
            "state": {
              "alert": "none",
              "level": 13,
              "on": false,
              "reachable": true
            }
          },
          "4": {
            "lastseen": "2021-02-15T05:00Z",
            "name": "Temperature Sensor Backup",
            "state": {
              "alert": "none",
              "level": 76,
              "on": true,
              "reachable": true
            }
          }
        },
        "output": [
          {
            "name": "Temperature Sensor A",
            "lastseen": "2021-02-15T05:02Z"
          },
          {
            "name": "Temperature Sensor B",
            "lastseen": "2021-02-15T05:01Z"
          },
          {
            "name": "Temperature Sensor Backup",
            "lastseen": "2021-02-15T05:00Z"
          }
        ]
      }
    ],
    "identifier": 66205415
  },
  {
    "context": [
      "\"How can split this TSV file into several JSON files, each with 1000 records?\"",
      "\"the first part of the pipeline consists of an invocation of jq with the -c option (for converting the TSV into a stream of JSON arrays, one per chunk); this is described below.\"",
      "\"def assemble(stream; $n):",
      "  foreach ((stream|[.]), null) as $item ({};",
      "     (.array|length) as $l",
      "     | if $item == null # eos",
      "       then .emit = (0 < $l and $l < $n)",
      "       else if $l == $n",
      "            then .array = $item",
      "            else .array += $item",
      "            end",
      "       | .emit = (.array|length == $n)",
      "       end;",
      "",
      "     if .emit then .array else empty end) ;",
      "",
      "",
      "def stream:",
      "  inputs",
      "  | split(\"\\t\")",
      "  | map_values(if . == \"\\\\N\" then \"\" else . end)",
      "  | map(split(\",\"))",
      "  | { tconst: .[0][0],",
      "      directors: .[1],",
      "      writers:   .[2] };",
      "      ",
      "assemble(stream; 1000)\"",
      "\"To skip the header, we omit the -n command-line option that would be used if there were no header: jq -Rc -f program.jq input.tsv\""
    ],
    "utterance": "Split the IMDb TSV file into multiple files, each containing up to 1000 records as arrays of objects with tconst, directors, and writers (handling '\\N' as empty arrays).",
    "expressions": [
      "def assemble(stream; $n):\n  foreach ((stream|[.]), null) as $item ({};\n     (.array|length) as $l\n     | if $item == null # eos\n       then .emit = (0 < $l and $l < $n)\n       else if $l == $n\n            then .array = $item\n            else .array += $item\n            end\n       | .emit = (.array|length == $n)\n       end;\n     if .emit then .array else empty end) ;\ndef stream:\n  inputs\n  | split(\"\\t\")\n  | map_values(if . == \"\\\\N\" then \"\" else . end)\n  | map(split(\",\"))\n  | { tconst: .[0][0],\n      directors: .[1],\n      writers:   .[2] };\nassemble(stream; 1000)"
    ],
    "data": [
      {
        "input": "tconst\tdirectors\twriters\ntt0000238\tnm0349785\t\\N\ntt0000239\tnm0349785\t\\N\ntt0000240\t\\N\t\\N\ntt0000241\tnm0349785\t\\N\ntt0000242\tnm0617588\tnm0617588\ntt0000243\tnm0349785\t\\N\ntt0000244\tnm0349785\t\\N\ntt0000245\t\\N\t\\N\ntt0000246\tnm0617588\t\\N\ntt0000247\tnm0002504,nm0005690,nm2156608\tnm0000636,nm0002504\ntt0000248\tnm0808310\t\\N\ntt0000249\tnm0808310\t\\N\ntt0000250\tnm0005717\t\\N\ntt0000251\tnm0177862\t\\N\n",
        "output": [
          [
            {
              "tconst": "tt0000238",
              "directors": [
                "nm0349785"
              ],
              "writers": []
            },
            {
              "tconst": "tt0000239",
              "directors": [
                "nm0349785"
              ],
              "writers": []
            },
            {
              "tconst": "tt0000240",
              "directors": [],
              "writers": []
            },
            {
              "tconst": "tt0000241",
              "directors": [
                "nm0349785"
              ],
              "writers": []
            },
            {
              "tconst": "tt0000242",
              "directors": [
                "nm0617588"
              ],
              "writers": [
                "nm0617588"
              ]
            },
            {
              "tconst": "tt0000243",
              "directors": [
                "nm0349785"
              ],
              "writers": []
            },
            {
              "tconst": "tt0000244",
              "directors": [
                "nm0349785"
              ],
              "writers": []
            },
            {
              "tconst": "tt0000245",
              "directors": [],
              "writers": []
            },
            {
              "tconst": "tt0000246",
              "directors": [
                "nm0617588"
              ],
              "writers": []
            },
            {
              "tconst": "tt0000247",
              "directors": [
                "nm0002504",
                "nm0005690",
                "nm2156608"
              ],
              "writers": [
                "nm0000636",
                "nm0002504"
              ]
            },
            {
              "tconst": "tt0000248",
              "directors": [
                "nm0808310"
              ],
              "writers": []
            },
            {
              "tconst": "tt0000249",
              "directors": [
                "nm0808310"
              ],
              "writers": []
            },
            {
              "tconst": "tt0000250",
              "directors": [
                "nm0005717"
              ],
              "writers": []
            },
            {
              "tconst": "tt0000251",
              "directors": [
                "nm0177862"
              ],
              "writers": []
            }
          ]
        ]
      }
    ],
    "identifier": 66133046
  }
]