공지사항:
2025년 4월 15일 전에 Earth Engine 사용을 위해 등록된 모든 비상업용 프로젝트는 Earth Engine 액세스를 유지하기 위해
비상업용 자격 요건을 인증해야 합니다.
그룹화된 감소 및 구역 통계
컬렉션을 사용해 정리하기
내 환경설정을 기준으로 콘텐츠를 저장하고 분류하세요.
reducer.group()
를 사용하여 감소기의 출력을 지정된 입력 값별로 그룹화하면 Image
또는 FeatureCollection
의 각 영역에서 통계를 가져올 수 있습니다. 예를 들어 각 주의 총 인구와 주택 수를 계산하기 위해 이 예에서는 인구 조사 블록 FeatureCollection
감소의 출력을 다음과 같이 그룹화합니다.
코드 편집기 (JavaScript)
// Load a collection of US census blocks.
var blocks = ee.FeatureCollection('TIGER/2010/Blocks');
// Compute sums of the specified properties, grouped by state code.
var sums = blocks
.filter(ee.Filter.and(
ee.Filter.neq('pop10', null),
ee.Filter.neq('housing10', null)))
.reduceColumns({
selectors: ['pop10', 'housing10', 'statefp10'],
reducer: ee.Reducer.sum().repeat(2).group({
groupField: 2,
groupName: 'state-code',
})
});
// Print the resultant Dictionary.
print(sums);
Python 설정
Python API 및 대화형 개발을 위한 geemap
사용에 관한 자세한 내용은
Python 환경 페이지를 참고하세요.
import ee
import geemap.core as geemap
Colab (Python)
# Load a collection of US census blocks.
blocks = ee.FeatureCollection('TIGER/2010/Blocks')
# Compute sums of the specified properties, grouped by state code.
sums = blocks.filter(
ee.Filter.And(
ee.Filter.neq('pop10', None), ee.Filter.neq('housing10', None)
)
).reduceColumns(
selectors=['pop10', 'housing10', 'statefp10'],
reducer=ee.Reducer.sum()
.repeat(2)
.group(groupField=2, groupName='state-code'),
)
# Print the resultant Dictionary.
display(sums)
groupField
인수는 그룹화할 코드가 포함된 선택자 배열의 입력 인덱스이고 groupName
인수는 그룹화 변수의 값을 저장할 속성의 이름을 지정합니다. 각 입력에 대해 reducer가 자동으로 반복되지 않으므로 repeat(2)
호출이 필요합니다.
image.reduceRegions()
의 출력을 그룹화하려면 정수 픽셀 값으로 그룹을 정의하는 그룹화 밴드를 지정하면 됩니다. 이러한 유형의 계산을 '지역 통계'라고도 하는데, 이때 지역은 그룹화 밴드로 지정되고 통계는 감소기에 의해 결정됩니다. 다음 예에서는 미국의 야간 조명 변화가 토지 피복 카테고리별로 그룹화되어 있습니다.
코드 편집기 (JavaScript)
// Load a region representing the United States
var region = ee.FeatureCollection('USDOS/LSIB_SIMPLE/2017')
.filter(ee.Filter.eq('country_na', 'United States'));
// Load MODIS land cover categories in 2001.
var landcover = ee.Image('MODIS/051/MCD12Q1/2001_01_01')
// Select the IGBP classification band.
.select('Land_Cover_Type_1');
// Load nightlights image inputs.
var nl2001 = ee.Image('NOAA/DMSP-OLS/NIGHTTIME_LIGHTS/F152001')
.select('stable_lights');
var nl2012 = ee.Image('NOAA/DMSP-OLS/NIGHTTIME_LIGHTS/F182012')
.select('stable_lights');
// Compute the nightlights decadal difference, add land cover codes.
var nlDiff = nl2012.subtract(nl2001).addBands(landcover);
// Grouped a mean reducer: change of nightlights by land cover category.
var means = nlDiff.reduceRegion({
reducer: ee.Reducer.mean().group({
groupField: 1,
groupName: 'code',
}),
geometry: region.geometry(),
scale: 1000,
maxPixels: 1e8
});
// Print the resultant Dictionary.
print(means);
Python 설정
Python API 및 대화형 개발을 위한 geemap
사용에 관한 자세한 내용은
Python 환경 페이지를 참고하세요.
import ee
import geemap.core as geemap
Colab (Python)
# Load a region representing the United States
region = ee.FeatureCollection('USDOS/LSIB_SIMPLE/2017').filter(
ee.Filter.eq('country_na', 'United States')
)
# Load MODIS land cover categories in 2001.
landcover = ee.Image('MODIS/051/MCD12Q1/2001_01_01').select(
# Select the IGBP classification band.
'Land_Cover_Type_1'
)
# Load nightlights image inputs.
nl_2001 = ee.Image('NOAA/DMSP-OLS/NIGHTTIME_LIGHTS/F152001').select(
'stable_lights'
)
nl_2012 = ee.Image('NOAA/DMSP-OLS/NIGHTTIME_LIGHTS/F182012').select(
'stable_lights'
)
# Compute the nightlights decadal difference, add land cover codes.
nl_diff = nl_2012.subtract(nl_2001).addBands(landcover)
# Grouped a mean reducer: change of nightlights by land cover category.
means = nl_diff.reduceRegion(
reducer=ee.Reducer.mean().group(groupField=1, groupName='code'),
geometry=region.geometry(),
scale=1000,
maxPixels=1e8,
)
# Print the resultant Dictionary.
display(means)
이 예에서 groupField
은 출력을 그룹화하는 영역을 포함하는 밴드의 색인입니다. 첫 번째 밴드는 색인 0, 두 번째 밴드는 색인 1 등으로 지정됩니다.
달리 명시되지 않는 한 이 페이지의 콘텐츠에는 Creative Commons Attribution 4.0 라이선스에 따라 라이선스가 부여되며, 코드 샘플에는 Apache 2.0 라이선스에 따라 라이선스가 부여됩니다. 자세한 내용은 Google Developers 사이트 정책을 참조하세요. 자바는 Oracle 및/또는 Oracle 계열사의 등록 상표입니다.
최종 업데이트: 2025-07-25(UTC)
[null,null,["최종 업데이트: 2025-07-25(UTC)"],[[["\u003cp\u003eUse \u003ccode\u003ereducer.group()\u003c/code\u003e with \u003ccode\u003ereduceColumns()\u003c/code\u003e on \u003ccode\u003eFeatureCollection\u003c/code\u003e to compute statistics for groups based on a property, like calculating total population per state.\u003c/p\u003e\n"],["\u003cp\u003eUtilize \u003ccode\u003ereducer.group()\u003c/code\u003e with \u003ccode\u003ereduceRegion()\u003c/code\u003e on \u003ccode\u003eImage\u003c/code\u003e to compute zonal statistics, such as averaging nightlight changes within different land cover categories.\u003c/p\u003e\n"],["\u003cp\u003eSpecify the \u003ccode\u003egroupField\u003c/code\u003e argument in \u003ccode\u003ereducer.group()\u003c/code\u003e as the index of the selector or band containing the grouping categories.\u003c/p\u003e\n"],["\u003cp\u003eThe \u003ccode\u003egroupName\u003c/code\u003e argument in \u003ccode\u003ereducer.group()\u003c/code\u003e determines the name of the property storing the grouping variable's value in the output dictionary.\u003c/p\u003e\n"],["\u003cp\u003eRemember to use \u003ccode\u003erepeat()\u003c/code\u003e with \u003ccode\u003ereduceColumns()\u003c/code\u003e when applying multiple reducers, ensuring calculations are performed for each selected property.\u003c/p\u003e\n"]]],[],null,["# Grouped Reductions and Zonal Statistics\n\nYou can get statistics in each zone of an `Image` or\n`FeatureCollection` by using `reducer.group()` to group the output\nof a reducer by the value of a specified input. For example, to compute the total\npopulation and number of housing units in each state, this example groups the output of\na reduction of a census block `FeatureCollection` as follows:\n\n### Code Editor (JavaScript)\n\n```javascript\n// Load a collection of US census blocks.\nvar blocks = ee.FeatureCollection('TIGER/2010/Blocks');\n\n// Compute sums of the specified properties, grouped by state code.\nvar sums = blocks\n .filter(ee.Filter.and(\n ee.Filter.neq('pop10', null),\n ee.Filter.neq('housing10', null)))\n .reduceColumns({\n selectors: ['pop10', 'housing10', 'statefp10'],\n reducer: ee.Reducer.sum().repeat(2).group({\n groupField: 2,\n groupName: 'state-code',\n })\n});\n\n// Print the resultant Dictionary.\nprint(sums);\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# Load a collection of US census blocks.\nblocks = ee.FeatureCollection('TIGER/2010/Blocks')\n\n# Compute sums of the specified properties, grouped by state code.\nsums = blocks.filter(\n ee.Filter.And(\n ee.Filter.neq('pop10', None), ee.Filter.neq('housing10', None)\n )\n).reduceColumns(\n selectors=['pop10', 'housing10', 'statefp10'],\n reducer=ee.Reducer.sum()\n .repeat(2)\n .group(groupField=2, groupName='state-code'),\n)\n\n# Print the resultant Dictionary.\ndisplay(sums)\n```\n\nThe `groupField` argument is the index of the input in the selectors array\nthat contains the codes by which to group, the `groupName` argument specifies\nthe name of the property to store the value of the grouping variable. Since the reducer\nis not automatically repeated for each input, the `repeat(2)` call is needed.\n\nTo group output of `image.reduceRegions()` you can specify a grouping band\nthat defines groups by integer pixel values. This type of computation is sometimes called\n\"zonal statistics\" where the zones are specified as the grouping band and the statistic\nis determined by the reducer. In the following example, change in nightlights in the\nUnited States is grouped by land cover category:\n\n### Code Editor (JavaScript)\n\n```javascript\n// Load a region representing the United States\nvar region = ee.FeatureCollection('USDOS/LSIB_SIMPLE/2017')\n .filter(ee.Filter.eq('country_na', 'United States'));\n\n// Load MODIS land cover categories in 2001.\nvar landcover = ee.Image('MODIS/051/MCD12Q1/2001_01_01')\n // Select the IGBP classification band.\n .select('Land_Cover_Type_1');\n\n// Load nightlights image inputs.\nvar nl2001 = ee.Image('NOAA/DMSP-OLS/NIGHTTIME_LIGHTS/F152001')\n .select('stable_lights');\nvar nl2012 = ee.Image('NOAA/DMSP-OLS/NIGHTTIME_LIGHTS/F182012')\n .select('stable_lights');\n\n// Compute the nightlights decadal difference, add land cover codes.\nvar nlDiff = nl2012.subtract(nl2001).addBands(landcover);\n\n// Grouped a mean reducer: change of nightlights by land cover category.\nvar means = nlDiff.reduceRegion({\n reducer: ee.Reducer.mean().group({\n groupField: 1,\n groupName: 'code',\n }),\n geometry: region.geometry(),\n scale: 1000,\n maxPixels: 1e8\n});\n\n// Print the resultant Dictionary.\nprint(means);\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# Load a region representing the United States\nregion = ee.FeatureCollection('USDOS/LSIB_SIMPLE/2017').filter(\n ee.Filter.eq('country_na', 'United States')\n)\n\n# Load MODIS land cover categories in 2001.\nlandcover = ee.Image('MODIS/051/MCD12Q1/2001_01_01').select(\n # Select the IGBP classification band.\n 'Land_Cover_Type_1'\n)\n\n# Load nightlights image inputs.\nnl_2001 = ee.Image('NOAA/DMSP-OLS/NIGHTTIME_LIGHTS/F152001').select(\n 'stable_lights'\n)\nnl_2012 = ee.Image('NOAA/DMSP-OLS/NIGHTTIME_LIGHTS/F182012').select(\n 'stable_lights'\n)\n\n# Compute the nightlights decadal difference, add land cover codes.\nnl_diff = nl_2012.subtract(nl_2001).addBands(landcover)\n\n# Grouped a mean reducer: change of nightlights by land cover category.\nmeans = nl_diff.reduceRegion(\n reducer=ee.Reducer.mean().group(groupField=1, groupName='code'),\n geometry=region.geometry(),\n scale=1000,\n maxPixels=1e8,\n)\n\n# Print the resultant Dictionary.\ndisplay(means)\n```\n\nNote that in this example, the `groupField` is the index of the band\ncontaining the zones by which to group the output. The first band is index 0, the second\nis index 1, etc."]]