byRegions#
- geetools.ImageAccessor.byRegions(regions, reducer='mean', bands=[], regionId='system:index', labels=[], scale=10000, crs=None, crsTransform=None, tileScale=1)#
Compute a reducer in each region of the image for eah band.
This method is returning a dictionary with all the features as keys and their reduced value for each band as values.
{ "feature1": {"band1": value1, "band2": value2, ...}, "feature2": {"bands1": value1, "band2": value2, ...}, ... }
- Parameters:
regions (ee.featurecollection) – The regions to compute the reducer in.
reducer (str | ee.Reducer) – The name of the reducer or a reducer object to use. Default is “mean”.
regionId (str) – The property used to label region. Defaults to “system:index”.
labels (list) – The labels to use for the output dictionary. Default to the band names.
bands (list) – The bands to compute the reducer on. Default to all bands.
scale (int) – The scale to use for the computation. Default is 10000m.
crs (str | None) – The projection to work in. If unspecified, the projection of the image’s first band is used. If specified in addition to scale, rescaled to the specified scale.
crsTransform (list | None) – The list of CRS transform values. This is a row-major ordering of the 3x2 transform matrix. This option is mutually exclusive with ‘scale’, and replaces any transform already set on the projection.
tileScale (float) – A scaling factor between 0.1 and 16 used to adjust aggregation tile size; setting a larger tileScale (e.g., 2 or 4) uses smaller tiles and may enable computations that run out of memory with the default.
- Returns:
A dictionary with all the bands as keys and their values in each region as a list.
- Return type:
See also
ee.Image.geetools.byBands: Compute a reducer for each band of the image in each region.ee.Image.geetools.plot_by_regions: Plot the reduced values for each region.
Examples
import ee, geetools ee.Initialize() ecoregions = ee.FeatureCollection("projects/google/charts_feature_example").select(["label", "value","warm"]) normClim = ee.ImageCollection('OREGONSTATE/PRISM/Norm91m').toBands() d = normClim.byregions(ecoregions, ee.Reducer.mean(), scale=10000) print(d.getInfo())