[[["Easy to understand","easyToUnderstand","thumb-up"],["Solved my problem","solvedMyProblem","thumb-up"],["Other","otherUp","thumb-up"]],[["Missing the information I need","missingTheInformationINeed","thumb-down"],["Too complicated / too many steps","tooComplicatedTooManySteps","thumb-down"],["Out of date","outOfDate","thumb-down"],["Samples / code issue","samplesCodeIssue","thumb-down"],["Other","otherDown","thumb-down"]],["Last updated 2025-07-08 UTC."],[[["\u003cp\u003eThe \u003ccode\u003eselect()\u003c/code\u003e method returns an ImageCollection with specified bands selected from each image within the collection.\u003c/p\u003e\n"],["\u003cp\u003eBand selection can be achieved using band names, numeric indices, or regular expressions.\u003c/p\u003e\n"],["\u003cp\u003eSelected bands can be renamed by providing a corresponding list of new names.\u003c/p\u003e\n"],["\u003cp\u003eThe method accepts a flexible combination of selectors, including strings, integers, and lists.\u003c/p\u003e\n"],["\u003cp\u003eRegular expressions enable versatile pattern matching for selecting multiple bands simultaneously.\u003c/p\u003e\n"]]],["The `select` method extracts specific bands from an ImageCollection, returning a new ImageCollection with those bands. Band selection can be done by name, index, or a list of these. New band names can be assigned using an optional list, which must match the number of selected bands. Regular expressions can also be used to select bands based on pattern matching. The code examples demonstrate these selection techniques for both JavaScript and Python.\n"],null,["# ee.ImageCollection.select\n\n\u003cbr /\u003e\n\nSelect bands from each image in a collection.\n\n\u003cbr /\u003e\n\nReturns the image collection with selected bands.\n\n| Usage | Returns |\n|------------------------------------------------|-----------------|\n| ImageCollection.select`(selectors, `*names*`)` | ImageCollection |\n\n| Argument | Type | Details |\n|-------------------------|--------------------------|------------------------------------------------------------------------------------|\n| this: `imagecollection` | ImageCollection | The ImageCollection instance. |\n| `selectors` | List\\\u003cObject\\\u003e | A list of names, regexes or numeric indices specifying the bands to select. |\n| `names` | List\\\u003cString\\\u003e, optional | A list of new names for the output bands. Must match the number of bands selected. |\n\nExamples\n--------\n\n### Code Editor (JavaScript)\n\n```javascript\n// A Sentinel-2 surface reflectance image collection.\nvar col = ee.ImageCollection('COPERNICUS/S2_SR')\n .filterBounds(ee.Geometry.Point(-122.152, 37.336))\n .filterDate('2021-01-01', '2021-02-01');\nprint('All band names', col.first().bandNames());\n\nprint('Select a band by name',\n col.select('B11').first().bandNames());\n\nprint('Select a band by index',\n col.select(10).first().bandNames());\n\nprint('Select bands using a list',\n col.select(['B11', 'B8', 'B3']).first().bandNames());\n\nprint('Select bands by an argument series',\n col.select('B11', 'B8', 'B3').first().bandNames());\n\nprint('Mixing string and integer selectors is valid',\n col.select(10, 'B8', 2).first().bandNames());\n\nprint('Rename selected bands using two corresponding lists',\n col.select(['B11', 'B8', 'B3'], ['SWIR1', 'NIR', 'Green'])\n .first().bandNames());\n\n// Use regular expressions to select bands.\nprint('Match \"QA\" followed by any two characters',\n col.select('QA..').first().bandNames());\n\nprint('Match \"B\" followed by any character, any number of times',\n col.select('B.*').first().bandNames());\n\nprint('Match \"B\" followed by any character, and any optional third character',\n col.select('B..?').first().bandNames());\n\nprint('Match \"B\" followed by a character in the range 6-8',\n col.select('B[6-8]').first().bandNames());\n\nprint('Match \"B\" followed by a character in the range 1-9 and then 1-2',\n col.select('B[1-9][1-2]').first().bandNames());\n\nprint('Match \"B\" or \"QA\" each followed by any character, any number of times.',\n col.select('B.*|QA.*').first().bandNames());\n```\nPython setup\n\nSee the [Python Environment](/earth-engine/guides/python_install) page for information on the Python API and using\n`geemap` for interactive development. \n\n```python\nimport ee\nimport geemap.core as geemap\n```\n\n### Colab (Python)\n\n```python\n# A Sentinel-2 surface reflectance image collection.\ncol = ee.ImageCollection('COPERNICUS/S2_SR').filterBounds(\n ee.Geometry.Point(-122.152, 37.336)\n ).filterDate('2021-01-01', '2021-02-01')\nprint('All band names', col.first().bandNames().getInfo())\n\nprint('Select a band by name:',\n col.select('B11').first().bandNames().getInfo())\n\nprint('Select a band by index:',\n col.select(10).first().bandNames().getInfo())\n\nprint('Select bands using a list:',\n col.select(['B11', 'B8', 'B3']).first().bandNames().getInfo())\n\nprint('Select bands by an argument series:',\n col.select('B11', 'B8', 'B3').first().bandNames().getInfo())\n\nprint('Mixing string and integer selectors is valid:',\n col.select(10, 'B8', 2).first().bandNames().getInfo())\n\nprint('Rename selected bands using two corresponding lists:',\n col.select(['B11', 'B8', 'B3'], ['SWIR1', 'NIR', 'Green'])\n .first().bandNames().getInfo())\n\n# Use regular expressions to select bands.\nprint('Match \"QA\" followed by any two characters:',\n col.select('QA..').first().bandNames().getInfo())\n\nprint('Match \"B\" followed by any character, any number of times:',\n col.select('B.*').first().bandNames().getInfo())\n\nprint('Match \"B\" followed by any character, and any optional third character:',\n col.select('B..?').first().bandNames().getInfo())\n\nprint('Match \"B\" followed by a character in the range 6-8:',\n col.select('B[6-8]').first().bandNames().getInfo())\n\nprint('Match \"B\" followed by a character in the range 1-9 and then 1-2:',\n col.select('B[1-9][1-2]').first().bandNames().getInfo())\n\nprint('Match \"B\" or \"QA\" each followed by any character, any number of times:',\n col.select('B.*|QA.*').first().bandNames().getInfo())\n```"]]