A bit like PostGIS ST_SummaryStats for files on disk
Project description
A bit like the PostGIS ST_SummaryStats function for rasters on your filesystem. Mostly we’re just stringing together some awesome libraries:
Install
Activate your project virtual environment, and then:
pip install winston
If you just want to use the command-line features, you could:
pip install --user winston
Usage
You can either use Winston on the command-line or as a module.
Command-line
To see your options, simply:
winston --help
For example, to get stats for all WKTs in a text file for a given raster:
winston some_file.tif -f wkts.txt
or just for one point, including raster metadata:
winston /path/to/data/*.tif -w 'POINT (-4.483545 54.150744)' -m
Since we require rasterio, you can also use the rio command-line tool to inspect your rasters:
rio insp /path/to/geo.tif
Read more in the Rasterio docs.
Module
You can also use Winston in your code:
>>> import rasterio
>>> from winston.stats import summary
>>> from shapely.geometry import Point
>>> src = rasterio.open('/path/to/raster.tif')
>>> print summary(src)
Summary(count=37324800, sum=49041320.0, mean=5.8627439, min=0.0, max=10.0, std=2.2037256)
>>> print summary(src, bounds=(4, 6))
Summary(count=37324800, sum=9569182.0, mean=5.1044292, min=4.0, max=5.9999995, std=0.56939822)
>>> print summary(src, bounds=(4, 6), mean_only=True)
5.09
>>> print summary(src, Point(-2.36, 51.38).buffer(0.25))
Summary(count=169, sum=1229.4401, mean=8.9740152, min=8.3602285, max=9.4269724, std=0.24473859)
Exporting results is reasonably simple with tablib:
>>> import rasterio
>>> import tablib
>>> from winston.stats import summary
>>> from shapely.geometry import Point
>>> src = rasterio.open('/path/to/raster.tif')
>>> shapes = [Point(x, y).buffer(0.25) for x, y in zip(range(5), range(5, 0, -1))]
>>> summaries = [summary(src, shape) for shape in shapes]
>>> d = tablib.Dataset()
>>> d.dict = [s.__dict__ for s in summaries]
>>> print d.headers
['count', 'sum', 'mean', 'min', 'max', 'std']
>>> open('output.csv', 'w').write(d.csv)
History
0.3.0 (2016-12-19)
Updated CLI defaults to be more… sane
Remove data_count from summary results
Now accept a exclude_nodata_value to be consistent with PostGIS
Added some basic tests
0.2.3 (2016-10-13)
Invert default value of all_touched flag to be consistent with Rasterio
Added missing requirement (six) and reorganised requirements files
0.2.2 (2016-10-13)
Bugfix in namedtuple parameter ordering (oops!)
0.2.1 (2016-10-12)
Accept WKT strings as well as GeoJSON & Shapely geometries
Fix the processing of ‘no result’ summaries
0.2.0 (2016-10-12)
winston.stats.summary:
now accepts Shapely geometries as well as GeoJSON-like objects
we no longer round results to 3 decimal places
the stats are now returned as a namedtuple rather than a list
0.1.1 (2016-10-12)
Minor packaging fixes.
0.1.0 (2016-10-12)
First release on PyPI.
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
File details
Details for the file winston-0.3.0.tar.gz
.
File metadata
- Download URL: winston-0.3.0.tar.gz
- Upload date:
- Size: 8.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4ff91b059cb992a70f92e6966746e1c0b4b7aa962a313644e61cf5682b7453b1 |
|
MD5 | 6ea6ef4b98309fdd09b17ad0d6bb0e66 |
|
BLAKE2b-256 | 4f2678d7e88f75b2b81c84bf301b2109732d33efffa55dd7945ff8721b5e6fad |