Skip to main content

Utility to search and download Sentinel-1 Imagery

Project description

sentinelsat

https://badge.fury.io/py/sentinelsat.svg https://travis-ci.org/ibamacsr/sentinelsat.svg https://coveralls.io/repos/ibamacsr/sentinelsat/badge.svg?branch=master&service=github Documentation gitter.im chat https://zenodo.org/badge/36093931.svg

Sentinelsat makes finding and downloading Copernicus Sentinel satellite images from the Sentinels Scientific Datahub easy.

It offers an easy to use command line interface.

sentinel search --sentinel2 --cloud 30 user password search_polygon.geojson

and a powerful Python API.

from sentinelsat.sentinel import SentinelAPI, get_coordinates

api = SentinelAPI('user', 'password')
products = api.query(get_coordinates('search_polygon.geojson'), \
                     producttype = 'SLC', \
                     orbitdirection='ASCENDING')
api.download_all(products)

Documentation is published at http://sentinelsat.readthedocs.io/.

Installation

Sentinelsat depends on homura, which depends on PycURL, so you might need to install some dependencies on your system.

Install sentinelsat through pip:

pip install sentinelsat

The documentation contains examples on how to install the dependencies for Ubuntu, Fedora and Windows.

Usage

Sentinelsat provides a Python Library and a Command Line Interface to search and download Sentinel products.

Python Library

# connect to the API
from sentinelsat.sentinel import SentinelAPI, get_coordinates
api = SentinelAPI('user', 'password', 'https://scihub.copernicus.eu/dhus')

# download single scene by known product id
api.download(<product_id>)

# search by polygon, time, and SciHub query keywords
products = api.query(get_coordinates('map.geojson'), \
                     '20151219', date(2015, 12, 29), \
                     platformname = 'Sentinel-2', \
                     cloudcoverpercentage = '[0 TO 30]')

# download all results from the search
api.download_all(products)

# GeoJSON FeatureCollection containing footprints and metadata of the scenes
api.get_footprints(products)

Valid search query keywords can be found at the ESA SciHub documentation.

Command Line Interface

A basic search query consists of a search polygon as well as the username and password to access the Scihub.

sentinel search [OPTIONS] <user> <password> <geojson>

Search areas are provided as GeoJSON polygons, which can be created with QGIS or geojson.io. If you do not specify a start and end date only products published in the last 24 hours will be queried.

Example

Search and download all Sentinel-1 scenes of type SLC, in descending orbit, for the year 2015.

sentinel search -s 20150101 -e 20151231 -d \
-q "producttype=SLC, orbitdirection=Descending" \
-u "https://scihub.copernicus.eu/dhus" <user> <password> <poly.geojson>

Options

-s

--start

TEXT

Start date of the query in the format YYYYMMDD.

-e

--end

TEXT

End date of the query in the format YYYYMMDD.

-d

--download

Download all results of the query.

-f

--footprints

Create geojson file search_footprints.geojson with footprints of the query result.

-p

--path

PATH

Set the path where the files will be saved.

-q

--query

TEXT

Extra search keywords you want to use in the query. Separate keywords with comma. Example: ‘producttype=GRD,polarisationmode=HH’.

-u

--url

TEXT

Define another API URL. Default URL is ‘https://scihub.copernicus.eu/apihub/’.

--md5

Verify the MD5 checksum and write corrupt product ids and filenames to corrupt_scenes.txt.

--sentinel1

Limit search to Sentinel-1 products.

--sentinel2

Limit search to Sentinel-2 products.

-c

--cloud

INT

Maximum cloud cover in percent. (Automatically sets –sentinel2)

--help

Show help message and exit.

--version

Show version number and exit.

Troubleshooting

The download from Scihub will fail if the server certificate cannot be verified because no default CA bundle is defined, as on Windows, or when the CA bundle is outdated. In most cases the easiest solution is to install or update certifi:

pip install -U certifi

You can also override the the path setting to the PEM file of the CA bundle using the pass_through_opts keyword argument when calling api.download() or api.download_all():

from pycurl import CAINFO
api.download_all(pass_through_opts={CAINFO: 'path/to/my/cacert.pem'})

Tests

To run the tests on sentinelsat:

git clone https://github.com/ibamacsr/sentinelsat.git
cd sentinelsat
pip install -e .[test]
export SENTINEL_USER=<your scihub username>
export SENTINEL_PASSWORD=<your scihub password>
py.test -v

By default, prerecorded responses to SciHub queries are used to not be affected by Scihub’s downtime. The only exceptions are downloading tests, which can be disabled with -m "not homura". To allow the tests to run actual queries on SciHub add --vcr disable to py.test arguments. If you wish to update the recordings use --vcr record_new or --vcr reset_all.

Documentation

To build the documentation:

git clone https://github.com/ibamacsr/sentinelsat.git
cd sentinelsat
pip install -e .[docs]
cd docs
make html

The full documentation is also published at http://sentinelsat.readthedocs.io/.

Changelog

See CHANGELOG.

Contributors

  • Wille Marcel

  • Kersten Clauss

  • Martin Valgur

  • Jonas Sølvsteen

  • Luca Delucchi

License

GPLv3+

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

sentinelsat-0.9.1.tar.gz (704.0 kB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

sentinelsat-0.9.1-py3-none-any.whl (17.8 kB view details)

Uploaded Python 3

sentinelsat-0.9.1-py2-none-any.whl (17.8 kB view details)

Uploaded Python 2

File details

Details for the file sentinelsat-0.9.1.tar.gz.

File metadata

  • Download URL: sentinelsat-0.9.1.tar.gz
  • Upload date:
  • Size: 704.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for sentinelsat-0.9.1.tar.gz
Algorithm Hash digest
SHA256 2ad43631d19be77c4313c42dd1d600e333d0ab35a2c9448c3af52ff0b71dea16
MD5 5ba4c1519f6db1a7f7c2411c8e5e0c21
BLAKE2b-256 e01b33c7f19dd5a589f53546462fa4e5f79fe5903c86e17313058a4eec58e858

See more details on using hashes here.

File details

Details for the file sentinelsat-0.9.1-py3-none-any.whl.

File metadata

File hashes

Hashes for sentinelsat-0.9.1-py3-none-any.whl
Algorithm Hash digest
SHA256 0b4e00772f84365143deb382b46e0468b6b1b750625fdaf731c8b1dd3de2114c
MD5 8ad7a7cafdcffe09f47ffc5208e57e68
BLAKE2b-256 5b7e21ab40e8530dc7366fa43901404881d62959b0f3bd541ccfc049b3a4b4f0

See more details on using hashes here.

File details

Details for the file sentinelsat-0.9.1-py2-none-any.whl.

File metadata

File hashes

Hashes for sentinelsat-0.9.1-py2-none-any.whl
Algorithm Hash digest
SHA256 ddc6202078cb289186437b5e6d839189ecaa58d67fb5ee09f4a58c955eda2c8d
MD5 efc42b70fca1352554eee60b26451966
BLAKE2b-256 3bea8880618d457412b668993a066f45589065197f189f130fbceee1b4527ac5

See more details on using hashes here.

Supported by

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