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')
api.query(
get_coordinates("search_polygon.geojson"),
producttype="SLC",
orbitdirection="ASCENDING"
)
api.download_all()
Documentation is published at http://sentinelsat.readthedocs.io/.
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.
Sentinelsat provides a Python Library and a Command Line Interface to search and download Sentinel products.
# 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
api.query(get_coordinates(map.geojson), \
"20151219", date(2015, 12, 29), \
keywords={"platformname": "Sentinel-2", \
"cloudcoverpercentage": "[0 TO 30]"})
# download all results from the search
api.download_all()
# GeoJSON FeatureCollection containing footprints and metadata of the scenes
api.get_footprints()
Valid search query keywords can be found at the ESA SciHub documentation.
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.
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>
-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. |
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'})
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
- Wille Marcel
- Kersten Clauss
- Martin Valgur
- Jonas Sølvsteen
GPLv3+