Skip to main content

sos4py is a convenience layer for Python environment to access services from SOS instances.

Project description

sos4py

https://img.shields.io/pypi/v/sos4py.svg

sos4py is a convenience layer for Python environment to access services, extract data, and allow querying from SOS instances.

  • Free software: Apache Software License 2.0

Features

  • Allows connection to an SOS service using OWSLib.

  • Explore and summarize service capabilities, sensor metadata, offerings, observed properties, available phenomena and features of interest.

  • Query requests to an SOS service for Get Data Availability.

  • Query requests to an SOS service for getting observation data.

  • Query requests to an SOS service for getting observation site data.

Usage

EXAMPLES OF THE PACKAGE CAN BE SEEN:: https://github.com/52North/sos4py/tree/master/examples

Connecting to an SOS service:
Description

Base class of a connection to a Sensor Observation Service. The result is class object SensorObservationService_2_0_0(object) of the OWSLib (<https://github.com/geopython/OWSLib/blob/master/owslib/swe/observation/sos200.py>)

Usage

def connection_sos(url, xml=None, username=None, password=None,):

Parameters

xmlstr

Xml file path.

usernamestr

Username to access the SOS service.

passwordstr

User password to access the SOS service.

Example

from sos4py.main import connection_sos

service = sos4py('http://sensorweb.demo.52north.org/52n-sos-webapp/sos/kvp')

Get capabilities functions (summaries):
Description

Construction class sos_2_0_0. Implements the the return of the function connection_sos() as input. The methods of the class can be used for metadata retrieval of sensors, and observation data queries.

Usage

class sos_2_0_0(self, url, version, xml=None, username=None, password=None):

Methods

sosServiceIdentification() The identification section of a SOS v2.0 capabilities document. This function queries the identification metadata available and returns the data as a pandas Series dataframe.

sosProvider() The provider section of an SOS v2.0 capabilities document. This function queries the provider metadata available and returns the data as a pandas Series dataframe.

sosOperationsMetadata() Elements in an OperationsMetadata object.This function queries the operations available of a SOS v2.0 capabilities document and returns the data as a pandas Series dataframe.

sosOfferings() Explore offerings section of an SOS v2.0 capabilities document. This function queries the offerings and returns the data as a pandas Series dataframe.

sosPhenomena() Queries a SOS v2.0 for all its phenomena. Returns a list of the phenomena ids.

sosFeaturesOfInterest() Queries a SOS v2.0 for all its features of interest. Returns a list of the feature of interest ids.

Examples

from sos4py.main import connection_sos

service = connection_sos('http://sensorweb.demo.52north.org/52n-sos-webapp/sos/kvp')

service.sosServiceIdentification()

service.sosProvider()

service.sosOperationsMetadata()

service.sosOfferings()

service.phenomena()

Get Data Availability function:
Description

Base class of a connection to a Sensor Observation Service. The result is class object SensorObservationService_2_0_0(object) of the OWSLib (<https://github.com/geopython/OWSLib/blob/master/owslib/swe/observation/sos200.py>)

Usage

def get_data_availability(object, procedures=None, observedProperties=None, featuresOfInterest=None, offerings=None, method=None, **kwargs)

Parameters

objectstr

Xml file path.

procedureslist of str

Query the data based on the availability of the indicated procedures.

observedProperties: list of str

Query the data based on the availability of the indicated observed properties.

featuresOfInterestlist of str

Query the data based on the availability of the indicated features of interest.

offeringslist of str

Query the data based on the availability of the indicated offerings.

methodstr

‘Get’ or ‘Post’ request parameter.

Examples

service.get_data_availability()

service.get_data_availability(procedures=['http://www.52north.org/test/procedure/6'], featuresOfInterest=['http://www.52north.org/test/featureOfInterest/6'])

Get sites function:
Description

Method to retrieve sites from an SOS. The result is a GeoDataFrame.

Usage

def get_sites(self, include_phenomena=False)

Parameters

include_phenomenaboolean, optional

Whether or not flags for the existance of phenomenona (e.g. water temperature) should be included (default is False)

Examples

service.get_sites()

service.get_sites(include_phenomena = True)

Get data function:
Description

Method to get observation data from an SOS. The result is a DataFrame.

Usage

def get_data(self, sites=None, phenomena=None, procedures=None, begin=None, end=None)

Parameters

sitesnon-empty list of str, optional

observation sites/sensor locations

phenomenanon-empty list of str, optional

phenomena, e.g. water temperature

proceduresnon-empty list of str, optional

measurement procedures of the observation, e.g. measurements in 2 m water depth

beginstr, optional if end is not provided

begin of time period in the form ‘YYYY-MM-DDThh:mm:ssZ’, e.g. ‘2020-01-01T10:00:00Z’

endstr, optional if begin is not provided

end of time period in the form ‘YYYY-MM-DDThh:mm:ssZ’, e.g. ‘2020-01-02T10:00:00Z’

It is recommended to provide at least one of sites, phenomena or procedures. Otherwise the request may take very long.

Examples

service.get_data()

service.get_data(sites=['Sensor location 1'],phenomena=['water temperature','salinity'])

Credits

This package was created with Cookiecutter and the audreyr/cookiecutter-pypackage project template.

History

0.1.0 (2020-05-09)

  • First release on PyPI.

0.2.0 (2020-08-20)

  • Add method get_feature_of_interest()

  • Add example for accessing and plotting sensor data

0.3.0 (2020-08-30)

  • Add method get_data()

  • Add method get_sites()

  • Add method sosFeaturesOfInterest()

  • Update example notebook for accessing and plotting sensor data

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

sos4py-0.3.0.tar.gz (20.4 kB view hashes)

Uploaded Source

Built Distribution

sos4py-0.3.0-py2.py3-none-any.whl (14.5 kB view hashes)

Uploaded Python 2 Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page