Skip to main content

Geometric objects, predicates, and operations

Project description

PostGIS-ish operations outside a database context for Pythoneers and Pythonistas.

http://farm3.static.flickr.com/2738/4511827859_b5822043b7_o_d.png

Shapely is a BSD-licensed Python package for manipulation and analysis of planar geometric objects. It is based on the widely deployed GEOS (the engine of PostGIS) and JTS (from which GEOS is ported) libraries. This C dependency is traded for the ability to execute with blazing speed. Shapely is not concerned with data formats or coordinate systems, but can be readily integrated with packages that are. For more details, see:

Dependencies

Shapely 1.2 depends on:

  • Python >=2.5,<3

  • libgeos_c >=3.1 (3.0 and below have not been tested, YMMV)

Installation

Windows users should use the executable installer, which contains the required GEOS DLL. Other users should acquire libgeos_c by any means, make sure that it is on the system library path, and install from the Python package index:

$ pip install Shapely

or from a source distribution with the setup script:

$ python setup.py install

Usage

Here is the canonical example of building an approximately circular patch by buffering a point:

>>> from shapely.geometry import Point
>>> patch = Point(0.0, 0.0).buffer(10.0)
>>> patch
<shapely.geometry.polygon.Polygon object at 0x...>
>>> patch.area
313.65484905459385

See the manual for comprehensive usage snippets and the dissolve.py and intersect.py example apps.

Integration

Shapely does not read or write data files, but it can serialize and deserialize using several well known formats and protocols. The shapely.wkb and shapely.wkt modules provide dumpers and loaders inspired by Python’s pickle module.:

>>> from shapely.wkt import dumps, loads
>>> dumps(loads('POINT (0 0)'))
'POINT (0.0000000000000000 0.0000000000000000)'

All linear objects, such as the rings of a polygon (like patch above), provide the Numpy array interface.:

>>> from numpy import asarray
>>> ag = asarray(patch.exterior)
>>> ag
array([[  1.00000000e+01,   0.00000000e+00],
       [  9.95184727e+00,  -9.80171403e-01],
       [  9.80785280e+00,  -1.95090322e+00],
       ...
       [  1.00000000e+01,   0.00000000e+00]])

That yields a numpy array of [x, y] arrays. This is not always exactly what one wants for plotting shapes with Matplotlib (for example), so Shapely 1.2 adds a xy property for obtaining separate arrays of coordinate x and y values.:

>>> x, y = patch.exterior.xy
>>> ax = asarray(x)
>>> ax
array([  1.00000000e+01,   9.95184727e+00,   9.80785280e+00,  ...])

Numpy arrays can also be adapted to Shapely linestrings:

>>> from shapely.geometry import asLineString
>>> asLineString(ag).length
62.806623139095073
>>> asLineString(ag).wkt
'LINESTRING (10.0000000000000000 0.0000000000000000, ...)'

Testing

Shapely uses a Zope-stye suite of unittests and doctests, exercised via setup.py.:

$ python setup.py test

Nosetests won’t run the tests properly; Zope doctest suites are not currently supported well by nose.

Support

Bugs may be reported and questions asked via https://github.com/Toblerity/Shapely.

Credits

Shapely is written by:

  • Sean Gillies

  • Aron Bierbaum

  • Kai Lautaportti

Patches contributed by:

  • Howard Butler

  • Frédéric Junod

  • Éric Lemoine

  • Jonathan Tartley

  • Kristian Thy

  • Oliver Tonnhofer

Additional help from:

  • Justin Bronn (GeoDjango) for ctypes inspiration

  • Martin Davis (JTS)

  • Jaakko Salli for the Windows distributions

  • Sandro Santilli, Mateusz Loskot, Paul Ramsey, et al (GEOS Project)

Major portions of this work were supported by a grant (for Pleiades) from the U.S. National Endowment for the Humanities (http://www.neh.gov).

Changes

1.2.13 (2011-09-16)

  • Fixed errors in speedups on 32bit systems when GEOS references memory above 2GB.

  • Add shapely.__version__ attribute.

  • Update the manual.

1.2.12 (2011-08-15)

  • Build Windows distributions with VC7 or VC9 as appropriate.

  • More verbose report on failure to speed up.

  • Fix for prepared geometries broken in 1.2.11.

  • DO NOT INSTALL 1.2.11

1.2.11 (2011-08-04)

  • Ignore AttributeError during exit.

  • PyPy 1.5 support.

  • Prevent operation on prepared geometry crasher (#12).

  • Optional Cython speedups for Windows.

  • Linux 3 platform support.

1.2.10 (2011-05-09)

  • Add optional Cython speedups.

  • Add is_cww predicate to LinearRing.

  • Add function that forces orientation of Polygons.

  • Disable build of speedups on Windows pending packaging work.

1.2.9 (2011-03-31)

  • Remove extra glob import.

  • Move examples to shapely.examples.

  • Add box() constructor for rectangular polygons.

  • Fix extraneous imports.

1.2.8 (2011-12-03)

  • New parallel_offset method (#6).

  • Support for Python 2.4.

1.2.7 (2010-11-05)

  • Support for Windows eggs.

1.2.6 (2010-10-21)

  • The geoms property of an empty collection yields [] instead of a ValueError (#3).

  • The coords and geometry type sproperties have the same behavior as above.

  • Ensure that z values carry through into products of operations (#4).

1.2.5 (2010-09-19)

  • Stop distributing docs/_build.

  • Include library fallbacks in test_dlls.py for linux platform.

1.2.4 (2010-09-09)

  • Raise AttributeError when there’s no backend support for a method.

  • Raise OSError if libgeos_c.so (or variants) can’t be found and loaded.

  • Add geos_c DLL loading support for linux platforms where find_library doesn’t work.

1.2.3 (2010-08-17)

  • Add mapping function.

  • Fix problem with GEOSisValidReason symbol for GEOS < 3.1.

1.2.2 (2010-07-23)

  • Add representative_point method.

1.2.1 (2010-06-23)

  • Fixed bounds of singular polygons.

  • Added shapely.validation.explain_validity function (#226).

1.2 (2010-05-27)

  • Final release.

1.2rc2 (2010-05-26)

  • Add examples and tests to MANIFEST.in.

  • Release candidate 2.

1.2rc1 (2010-05-25)

  • Release candidate.

1.2b7 (2010-04-22)

  • Memory leak associated with new empty geometry state fixed.

1.2b6 (2010-04-13)

  • Broken GeometryCollection fixed.

1.2b5 (2010-04-09)

  • Objects can be constructed from others of the same type, thereby making copies. Collections can be constructed from sequences of objects, also making copies.

  • Collections are now iterators over their component objects.

  • New code for manual figures, using the descartes package.

1.2b4 (2010-03-19)

  • Adds support for the “sunos5” platform.

1.2b3 (2010-02-28)

  • Only provide simplification implementations for GEOS C API >= 1.5.

1.2b2 (2010-02-19)

  • Fix cascaded_union bug introduced in 1.2b1 (#212).

1.2b1 (2010-02-18)

  • Update the README. Remove cruft from setup.py. Add some version 1.2 metadata regarding required Python version (>=2.5,<3) and external dependency (libgeos_c >= 3.1).

1.2a6 (2010-02-09)

  • Add accessor for separate arrays of X and Y values (#210).

TODO: fill gap here

1.2a1 (2010-01-20)

  • Proper prototyping of WKB writer, and avoidance of errors on 64-bit systems (#191).

  • Prototype libgeos_c functions in a way that lets py2exe apps import shapely (#189).

1.2 Branched (2009-09-19)

1.0.12 (2009-04-09)

  • Fix for references held by topology and predicate descriptors.

1.0.11 (2008-11-20)

  • Work around bug in GEOS 2.2.3, GEOSCoordSeq_getOrdinate not exported properly (#178).

1.0.10 (2008-11-17)

  • Fixed compatibility with GEOS 2.2.3 that was broken in 1.0.8 release (#176).

1.0.9 (2008-11-16)

  • Find and load MacPorts libgeos.

1.0.8 (2008-11-01)

  • Fill out GEOS function result and argument types to prevent faults on a 64-bit arch.

1.0.7 (2008-08-22)

  • Polygon rings now have the same dimensions as parent (#168).

  • Eliminated reference cycles in polygons (#169).

1.0.6 (2008-07-10)

  • Fixed adaptation of multi polygon data.

  • Raise exceptions earlier from binary predicates.

  • Beginning distributing new windows DLLs (#166).

1.0.5 (2008-05-20)

  • Added access to GEOS polygonizer function.

  • Raise exception when insufficient coordinate tuples are passed to LinearRing constructor (#164).

1.0.4 (2008-05-01)

  • Disentangle Python and topological equality (#163).

  • Add shape(), a factory that copies coordinates from a geo interface provider. To be used instead of asShape() unless you really need to store coordinates outside shapely for efficient use in other code.

  • Cache GEOS geometries in adapters (#163).

1.0.3 (2008-04-09)

  • Do not release GIL when calling GEOS functions (#158).

  • Prevent faults when chaining multiple GEOS operators (#159).

1.0.2 (2008-02-26)

  • Fix loss of dimensionality in polygon rings (#155).

1.0.1 (2008-02-08)

  • Allow chaining expressions involving coordinate sequences and geometry parts (#151).

  • Protect against abnormal use of coordinate accessors (#152).

  • Coordinate sequences now implement the numpy array protocol (#153).

1.0 (2008-01-18)

  • Final release.

1.0 RC2 (2008-01-16)

  • Added temporary solution for #149.

1.0 RC1 (2008-01-14)

  • First release candidate

Project details


Release history Release notifications | RSS feed

Download files

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

Source Distribution

Shapely-1.2.13.tar.gz (91.8 kB view details)

Uploaded Source

Built Distributions

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

Shapely-1.2.13.win-amd64-py2.7.exe (1.5 MB view details)

Uploaded Source

Shapely-1.2.13.win-amd64-py2.6.exe (1.5 MB view details)

Uploaded Source

Shapely-1.2.13.win32-py2.7.exe (1.2 MB view details)

Uploaded Source

Shapely-1.2.13.win32-py2.6.exe (1.2 MB view details)

Uploaded Source

Shapely-1.2.13.win32-py2.5.exe (918.0 kB view details)

Uploaded Source

Shapely-1.2.13-py2.7-win-amd64.egg (1.4 MB view details)

Uploaded Egg

Shapely-1.2.13-py2.7-win32.egg (1.0 MB view details)

Uploaded Egg

Shapely-1.2.13-py2.6-win-amd64.egg (1.4 MB view details)

Uploaded Egg

Shapely-1.2.13-py2.6-win32.egg (1.0 MB view details)

Uploaded Egg

Shapely-1.2.13-py2.5-win32.egg (918.0 kB view details)

Uploaded Egg

File details

Details for the file Shapely-1.2.13.tar.gz.

File metadata

  • Download URL: Shapely-1.2.13.tar.gz
  • Upload date:
  • Size: 91.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for Shapely-1.2.13.tar.gz
Algorithm Hash digest
SHA256 64310a22d2f1c1d5f85de0f8ac08cf360ce1eac5cd78a84e8e4185cc92128c86
MD5 c39a3b26a6ec6139fab1ba34a78263a2
BLAKE2b-256 214554a3f69a58388c86c3ad0f7625bbbbf4b2508232017f85246fbdfe8496e5

See more details on using hashes here.

File details

Details for the file Shapely-1.2.13.win-amd64-py2.7.exe.

File metadata

File hashes

Hashes for Shapely-1.2.13.win-amd64-py2.7.exe
Algorithm Hash digest
SHA256 e265c8966923ed83e615fccac5a22960223f9a9bdfea3a5fed0ca292cc17d42d
MD5 ac3171a106d97f2833390947ecfce3d7
BLAKE2b-256 23fa59edda28018ffe3f1d062a6120fd2751b733cefa820ee77388613ddc8d1f

See more details on using hashes here.

File details

Details for the file Shapely-1.2.13.win-amd64-py2.6.exe.

File metadata

File hashes

Hashes for Shapely-1.2.13.win-amd64-py2.6.exe
Algorithm Hash digest
SHA256 ae2cdb82bc1244c03c9d1a913fa61056bff47ae25aad0d54064c69168ad394e8
MD5 5432249e44ed900ce6f105c6394047c3
BLAKE2b-256 24b578f53cbbe151f92ad7e1e093a3eeb28fd3c658b896c9dc65af8c05e6bd16

See more details on using hashes here.

File details

Details for the file Shapely-1.2.13.win32-py2.7.exe.

File metadata

File hashes

Hashes for Shapely-1.2.13.win32-py2.7.exe
Algorithm Hash digest
SHA256 b8ea152471b75dc207785e798178c463b6334fbb3f4e660fb247318f7ad211fe
MD5 9b8bb8f2b3302c4c2cd011f820397ec3
BLAKE2b-256 57e98a289a0b6e1a2f50986e1a863f88eaa9b6a895daecc359fe597c7d67d365

See more details on using hashes here.

File details

Details for the file Shapely-1.2.13.win32-py2.6.exe.

File metadata

File hashes

Hashes for Shapely-1.2.13.win32-py2.6.exe
Algorithm Hash digest
SHA256 330a3a1466b97088f6ab0310ff80d2bac396fe1e1178fd83b6bea741978412b4
MD5 316c49d5e1ad3ffafb2ee91f51925b94
BLAKE2b-256 7b5eee0ce4b7146ebcd285cf93ccf50b1d019179ee99a01b302c443f5b03db0d

See more details on using hashes here.

File details

Details for the file Shapely-1.2.13.win32-py2.5.exe.

File metadata

File hashes

Hashes for Shapely-1.2.13.win32-py2.5.exe
Algorithm Hash digest
SHA256 f89a3b320ef3bd09f3e79c8314bc73876d133f278c1c7b7ba139ee71cf3eccb0
MD5 93f6db97f7d9627ade174a3c21026ed7
BLAKE2b-256 4f6eae5886558d67b181b0482b4ff94625a63e4d8bcd9ca97375122449214e7d

See more details on using hashes here.

File details

Details for the file Shapely-1.2.13-py2.7-win-amd64.egg.

File metadata

File hashes

Hashes for Shapely-1.2.13-py2.7-win-amd64.egg
Algorithm Hash digest
SHA256 ce0bf09465cde06c7c69a5486d4daa3fa165e62eaf6f551feeb039e59f88b91f
MD5 e5a6edacfa035e52aa7fe986818bf011
BLAKE2b-256 89c9861c202436e691c506157aed97c1a0360c123226f79878e7f2fe6ac8da6f

See more details on using hashes here.

File details

Details for the file Shapely-1.2.13-py2.7-win32.egg.

File metadata

File hashes

Hashes for Shapely-1.2.13-py2.7-win32.egg
Algorithm Hash digest
SHA256 78b07d65cad4ba291488ad5214550f0e132f50f972ad64016fe7e4300df210b5
MD5 14a5a27b2a1e790dd16e91027f4fc954
BLAKE2b-256 66be20f55411c930a775c9621923a49aeda5be97df863710aae45b196624f576

See more details on using hashes here.

File details

Details for the file Shapely-1.2.13-py2.6-win-amd64.egg.

File metadata

File hashes

Hashes for Shapely-1.2.13-py2.6-win-amd64.egg
Algorithm Hash digest
SHA256 8566be83c336f4b362e702898db470e0fd2f0071dfc9864771fefd5ea9bdbf1e
MD5 b3483d28e207271326d56458dbff646f
BLAKE2b-256 ec9e75457724aac5421f8b2832c9071677f4214ea37561b2fec130a4b7c64378

See more details on using hashes here.

File details

Details for the file Shapely-1.2.13-py2.6-win32.egg.

File metadata

File hashes

Hashes for Shapely-1.2.13-py2.6-win32.egg
Algorithm Hash digest
SHA256 449c178eb33f5bde75efc75b1164b8595cb991d0df5243f7f2f0a4c2a39ed149
MD5 5b97164dde436d079e4be1b7d35ed4c0
BLAKE2b-256 15ee23682b2b74219c0514604d48383dfe88a9bff535747cc3724624235bcfe8

See more details on using hashes here.

File details

Details for the file Shapely-1.2.13-py2.5-win32.egg.

File metadata

File hashes

Hashes for Shapely-1.2.13-py2.5-win32.egg
Algorithm Hash digest
SHA256 8c17ed451dd168f5bcac43faa658594bb1f5a9bd17c4b29fb60905ecc56d728d
MD5 f3164f0df0f97263a10ca05e5cab7fb5
BLAKE2b-256 58d80c89399163664a1e9489a5746771c5b923b41237605270fc678ccb0c96aa

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