Skip to main content

Geometric objects, predicates, and operations

Project description

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

http://farm3.staticflickr.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, ...)'

Shapely can also integrate with other Python GIS packages using data modeled after GeoJSON.

>>> import json
>>> from shapely.geometry import mapping, shape
>>> s = shape(json.loads('{"type": "Point", "coordinates": [0.0, 0.0]}'))
>>> s
<shapely.geometry.point.Point object at 0x...>
>>> print(json.dumps(mapping(s)))
{"type": "Point", "coordinates": [0.0, 0.0]}

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

Please discuss Shapely with us at http://lists.gispython.org/mailman/listinfo/community.

Bugs may be reported at https://github.com/Toblerity/Shapely.

Credits

Shapely is written by:

  • Sean Gillies

  • Aron Bierbaum

  • Kai Lautaportti

  • Oliver Tonnhofer

Patches contributed by:

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.18 (2013-07-23)

  • Add shapely.ops.transform.

  • Permit empty sequences in collection constructors (#49, #50).

  • Individual polygons in MultiPolygon.__geo_interface__ are changed to tuples to match Polygon.__geo_interface__ (#51).

  • Add shapely.ops.polygonize_full (#57).

1.2.17 (2013-01-27)

  • Avoid circular import between wkt/wkb and geometry.base by moving calls to GEOS serializers to the latter module.

  • Set _ndim when unpickling (issue #6).

  • Don’t install DLLs to Python’s DLL directory (#37).

  • Add affinity module of affine transformation (#31).

  • Fix NameError that blocked installation with PyPy (#40, #41).

1.2.16 (2012-09-18)

  • Add ops.unary_union function.

  • Alias ops.cascaded_union to ops.unary_union when GEOS CAPI >= (1,7,0).

  • Add geos_version_string attribute to shapely.geos.

  • Ensure parent is set when child geometry is accessed.

  • Generate _speedups.c using Cython when building from repo when missing, stale, or the build target is “sdist”.

  • The is_simple predicate of invalid, self-intersecting linear rings now returns False.

  • Remove VERSION.txt from repo, it’s now written by the distutils setup script with value of shapely.__version__.

1.2.15 (2012-06-27)

  • Eliminate numerical sensitivity in a method chaining test (Debian bug #663210).

  • Account for cascaded union of random buffered test points being a polygon or multipolygon (Debian bug #666655).

  • Use Cython to build speedups if it is installed.

  • Avoid stumbling over SVN revision numbers in GEOS C API version strings.

1.2.14 (2012-01-23)

  • A geometry’s coords property is now sliceable, yielding a list of coordinate values.

  • Homogeneous collections are now sliceable, yielding a new collection of the same type.

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.18.tar.gz (112.0 kB view details)

Uploaded Source

Built Distributions

Shapely-1.2.18.win-amd64-py2.7.exe (2.1 MB view details)

Uploaded Source

Shapely-1.2.18.win-amd64-py2.6.exe (2.1 MB view details)

Uploaded Source

Shapely-1.2.18.win32-py2.7.exe (1.6 MB view details)

Uploaded Source

Shapely-1.2.18.win32-py2.6.exe (1.6 MB view details)

Uploaded Source

Shapely-1.2.18-py2.7-win-amd64.egg (2.0 MB view details)

Uploaded Source

Shapely-1.2.18-py2.7-win32.egg (1.5 MB view details)

Uploaded Source

Shapely-1.2.18-py2.6-win-amd64.egg (2.0 MB view details)

Uploaded Source

Shapely-1.2.18-py2.6-win32.egg (1.5 MB view details)

Uploaded Source

File details

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

File metadata

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

File hashes

Hashes for Shapely-1.2.18.tar.gz
Algorithm Hash digest
SHA256 b3307b008e1cf96923f0e41a54b39e4ac316cdfa038b26ccbfc47a99cb69573c
MD5 53ad33214886e729b2d0de488eb9f115
BLAKE2b-256 7e51d8f73b778a629f1efe700fc86ecaa1d96e1ed25d6ab249940053079a7cb1

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for Shapely-1.2.18.win-amd64-py2.7.exe
Algorithm Hash digest
SHA256 e97cfb2537bc20c2e5168bad92c152c171039e93cfdd2461ffe7e876405f2be7
MD5 60e37992b7bce141cbb092780d5f3177
BLAKE2b-256 0c59bd73445fe318a6d0222a3458f0bafe65fd1bae72bf47186f5482b32b44fc

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for Shapely-1.2.18.win-amd64-py2.6.exe
Algorithm Hash digest
SHA256 82eb4a104145dc8dc59af03f5fac7a01c583a72415b66fa3460b5b678875253b
MD5 a55a27619dfbbe00c847c37c8b40cc86
BLAKE2b-256 36cf5d56a2a34b37640deb2f2a6cc6af7d768d9166e854d6e32cc6d101d614b6

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for Shapely-1.2.18.win32-py2.7.exe
Algorithm Hash digest
SHA256 7e8ac06549aa9732ab929e6c54122c374bbf14fb810197be2dd5fb4d9a8b829a
MD5 ceaa6cd35c75b724dd49b0f15b8d0f4e
BLAKE2b-256 caffd420b265e041e45e8543d9f2df3a340470ecf6420b535a99adb92e69331b

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for Shapely-1.2.18.win32-py2.6.exe
Algorithm Hash digest
SHA256 b54d467a41e2b49d93aef3e397c70b3f8b89b016533f97066daf3afa7fd1e1db
MD5 4e4ce9c170e2cdbf82b1247a180b1524
BLAKE2b-256 65c83b4326b4dbfa0454eabe9ab91d6516cde7960e24efbb385e5d74310296e8

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for Shapely-1.2.18-py2.7-win-amd64.egg
Algorithm Hash digest
SHA256 eb21bb2fc717968356b3390a5a503ab6d5f71547cb74dc905b0e2a8f9abaf0a3
MD5 67a5b4343af4e807f496565de60ce1ef
BLAKE2b-256 6300f2d6141ab433f0e1b1af75334058be7401b4c23cd61789cd117f60823561

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for Shapely-1.2.18-py2.7-win32.egg
Algorithm Hash digest
SHA256 a81082c4e9f5e57ed59479adb55cd5b603a034fb1616a58f55ba8d7fb43a5617
MD5 60307a7412d02889361571b81770253e
BLAKE2b-256 a68ea18cfc9860f1e2a07b26e59196753339b99b4904f0ef062440093c8227d5

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for Shapely-1.2.18-py2.6-win-amd64.egg
Algorithm Hash digest
SHA256 f668fd282c592b8e5f02c354d61c991c63b5bb01a30acb0c6ade7918e8669033
MD5 6db26f25c35311fddb8592d7274bf12b
BLAKE2b-256 39cff60138b0f3021876e8e034f249e0ef096a99c62888cc7474d41f39949806

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for Shapely-1.2.18-py2.6-win32.egg
Algorithm Hash digest
SHA256 49fd6237e63f859b81920879e31edac4fb427c0ff9d0f9427b9ac58786e2ee58
MD5 aad0a834f01f5a0ad38b3cc92f96c588
BLAKE2b-256 ee40e08de84ed9b79fc03ae976426a563e91e63dc4a91d7f05c611adcec3fbc3

See more details on using hashes here.

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