mirror of
https://github.com/google/earthengine-api.git
synced 2025-12-08 19:26:12 +00:00
197 lines
6.1 KiB
Python
197 lines
6.1 KiB
Python
"""Base class for Image, Feature and Collection.
|
|
|
|
This class is never intended to be instantiated by the user.
|
|
"""
|
|
|
|
from __future__ import annotations
|
|
|
|
import datetime
|
|
from typing import Any
|
|
|
|
from ee import _arg_types
|
|
from ee import _utils
|
|
from ee import apifunction
|
|
from ee import computedobject
|
|
from ee import dictionary
|
|
from ee import ee_array
|
|
from ee import ee_exception
|
|
from ee import ee_list
|
|
from ee import ee_number
|
|
from ee import ee_string
|
|
|
|
|
|
class Element(computedobject.ComputedObject):
|
|
"""Base class for ImageCollection and FeatureCollection."""
|
|
|
|
_initialized = False
|
|
|
|
# pylint: disable-next=useless-parent-delegation
|
|
@_utils.accept_opt_prefix('opt_varName')
|
|
def __init__(
|
|
self,
|
|
func: apifunction.ApiFunction | None,
|
|
args: dict[str, Any] | None,
|
|
varName: str | None = None, # pylint: disable=g-bad-name
|
|
):
|
|
"""Constructs a collection by initializing its ComputedObject."""
|
|
super().__init__(func, args, varName)
|
|
|
|
@classmethod
|
|
def initialize(cls) -> None:
|
|
"""Imports API functions to this class."""
|
|
if not cls._initialized:
|
|
apifunction.ApiFunction.importApi(cls, cls.name(), cls.name())
|
|
cls._initialized = True
|
|
|
|
@classmethod
|
|
def reset(cls) -> None:
|
|
"""Removes imported API functions from this class."""
|
|
apifunction.ApiFunction.clearApi(cls)
|
|
cls._initialized = False
|
|
|
|
@staticmethod
|
|
def name() -> str:
|
|
return 'Element'
|
|
|
|
# NOTE: Image.copyProperties overrides this method.
|
|
# NOTE: source is marked as optional in the API, but is required for users.
|
|
def copyProperties(
|
|
self,
|
|
source: _arg_types.Element,
|
|
properties: _arg_types.List | None = None,
|
|
exclude: _arg_types.List | None = None,
|
|
) -> Element:
|
|
"""Copies metadata properties from one element to another.
|
|
|
|
Args:
|
|
source: The object from which to copy the properties.
|
|
properties: The properties to copy. If omitted, all ordinary (i.e.
|
|
non-system) properties are copied.
|
|
exclude: The list of properties to exclude when copying all properties.
|
|
Must not be specified if properties is.
|
|
|
|
Returns:
|
|
An element with the specified properties copied from the source element.
|
|
"""
|
|
|
|
return apifunction.ApiFunction.call_(
|
|
'Element.copyProperties', self, source, properties, exclude
|
|
)
|
|
|
|
# pylint: disable-next=redefined-builtin
|
|
def get(self, property: _arg_types.String) -> computedobject.ComputedObject:
|
|
"""Returns a property from a feature."""
|
|
|
|
return apifunction.ApiFunction.call_('Element.get', self, property)
|
|
|
|
# pylint: disable-next=redefined-builtin
|
|
def getArray(self, property: _arg_types.String) -> ee_array.Array:
|
|
"""Returns a property from a feature as an array.
|
|
|
|
Args:
|
|
property: The property to extract.
|
|
"""
|
|
|
|
return apifunction.ApiFunction.call_('Element.getArray', self, property)
|
|
|
|
# pylint: disable-next=redefined-builtin
|
|
def getNumber(self, property: _arg_types.String) -> ee_number.Number:
|
|
"""Returns a property from a feature as a number.
|
|
|
|
Args:
|
|
property: The property to extract.
|
|
"""
|
|
|
|
return apifunction.ApiFunction.call_('Element.getNumber', self, property)
|
|
|
|
# pylint: disable-next=redefined-builtin
|
|
def getString(self, property: _arg_types.String) -> ee_string.String:
|
|
"""Returns a property from a feature as a string.
|
|
|
|
Args:
|
|
property: The property to extract.
|
|
"""
|
|
|
|
return apifunction.ApiFunction.call_('Element.getString', self, property)
|
|
|
|
def propertyNames(self) -> ee_list.List:
|
|
"""Returns the names of properties on this element."""
|
|
|
|
return apifunction.ApiFunction.call_('Element.propertyNames', self)
|
|
|
|
def set(
|
|
self,
|
|
*args: (
|
|
dict[str, Any] |
|
|
float |
|
|
str |
|
|
datetime.datetime |
|
|
computedobject.ComputedObject
|
|
),
|
|
) -> Element:
|
|
"""Overrides one or more metadata properties of an Element.
|
|
|
|
Args:
|
|
*args: Either a dictionary of properties, or a vararg sequence of
|
|
properties, e.g., key1, value1, key2, value2, ...
|
|
|
|
Returns:
|
|
The element with the specified properties overridden.
|
|
"""
|
|
if len(args) == 1:
|
|
properties = args[0]
|
|
|
|
# If this is a keyword call, unwrap it.
|
|
if (isinstance(properties, dict) and
|
|
(len(properties) == 1 and 'properties' in properties) and
|
|
isinstance(properties['properties'],
|
|
(dict, computedobject.ComputedObject))):
|
|
# Looks like a call with keyword parameters. Extract them.
|
|
properties = properties['properties']
|
|
|
|
if isinstance(properties, dict):
|
|
# Still a plain object. Extract its keys. Setting the keys separately
|
|
# allows filter propagation.
|
|
result = self
|
|
for key, value in properties.items():
|
|
result = apifunction.ApiFunction.call_(
|
|
'Element.set', result, key, value)
|
|
elif (isinstance(properties, computedobject.ComputedObject) and
|
|
apifunction.ApiFunction.lookupInternal('Element.setMulti')):
|
|
# A computed dictionary. Can't set each key separately.
|
|
result = apifunction.ApiFunction.call_(
|
|
'Element.setMulti', self, properties)
|
|
else:
|
|
raise ee_exception.EEException(
|
|
'When Element.set() is passed one argument, '
|
|
'it must be a dictionary.')
|
|
else:
|
|
# Interpret as key1, value1, key2, value2, ...
|
|
if len(args) % 2 != 0:
|
|
raise ee_exception.EEException(
|
|
'When Element.set() is passed multiple arguments, there '
|
|
'must be an even number of them.')
|
|
result = self
|
|
for i in range(0, len(args), 2):
|
|
key = args[i]
|
|
value = args[i + 1]
|
|
result = apifunction.ApiFunction.call_(
|
|
'Element.set', result, key, value)
|
|
|
|
# Manually cast the result to an image.
|
|
return self._cast(result)
|
|
|
|
def toDictionary(
|
|
self, properties: _arg_types.List | None = None
|
|
) -> dictionary.Dictionary:
|
|
"""Returns properties from a feature as a dictionary.
|
|
|
|
Args:
|
|
properties: The list of properties to extract. Defaults to all non-system
|
|
properties
|
|
"""
|
|
|
|
return apifunction.ApiFunction.call_(
|
|
'Element.toDictionary', self, properties
|
|
)
|