Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/geopy/geopy
Geocoding library for Python.
https://github.com/geopy/geopy
geocoder geocoding python
Last synced: 4 days ago
JSON representation
Geocoding library for Python.
- Host: GitHub
- URL: https://github.com/geopy/geopy
- Owner: geopy
- License: mit
- Created: 2010-03-04T22:05:28.000Z (almost 15 years ago)
- Default Branch: master
- Last Pushed: 2024-08-14T15:31:25.000Z (5 months ago)
- Last Synced: 2025-01-06T15:05:11.419Z (11 days ago)
- Topics: geocoder, geocoding, python
- Language: Python
- Homepage: https://geopy.readthedocs.io/
- Size: 2.55 MB
- Stars: 4,541
- Watchers: 90
- Forks: 650
- Open Issues: 43
-
Metadata Files:
- Readme: README.rst
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Authors: AUTHORS
Awesome Lists containing this project
- awesome-python-resources - GitHub - 7% open · ⏱️ 07.08.2022): (地理位置)
- awesome-python-machine-learning-resources - GitHub - 7% open · ⏱️ 07.08.2022): (地理Geo处理)
README
geopy
=====.. image:: https://img.shields.io/pypi/v/geopy.svg?style=flat-square
:target: https://pypi.python.org/pypi/geopy/
:alt: Latest Version.. image:: https://img.shields.io/github/actions/workflow/status/geopy/geopy/ci.yml?branch=master&style=flat-square
:target: https://github.com/geopy/geopy/actions/workflows/ci.yml?query=branch%3Amaster
:alt: Build Status.. image:: https://img.shields.io/github/license/geopy/geopy.svg?style=flat-square
:target: https://pypi.python.org/pypi/geopy/
:alt: Licensegeopy is a Python client for several popular geocoding web
services.geopy makes it easy for Python developers to locate the coordinates of
addresses, cities, countries, and landmarks across the globe using
third-party geocoders and other data sources.geopy includes geocoder classes for the `OpenStreetMap Nominatim`_,
`Google Geocoding API (V3)`_, and many other geocoding services.
The full list is available on the `Geocoders doc section`_.
Geocoder classes are located in `geopy.geocoders`_... _OpenStreetMap Nominatim: https://nominatim.org
.. _Google Geocoding API (V3): https://developers.google.com/maps/documentation/geocoding/
.. _Geocoders doc section: https://geopy.readthedocs.io/en/latest/#geocoders
.. _geopy.geocoders: https://github.com/geopy/geopy/tree/master/geopy/geocodersgeopy is tested against CPython (versions 3.7, 3.8, 3.9, 3.10, 3.11, 3.12)
and PyPy3. geopy 1.x line also supported CPython 2.7, 3.4 and PyPy2.© geopy contributors 2006-2018 (see AUTHORS) under the `MIT
License `__.Installation
------------Install using `pip `__ with:
::
pip install geopy
Or, `download a wheel or source archive from
PyPI `__.Geocoding
---------To geolocate a query to an address and coordinates:
.. code:: pycon
>>> from geopy.geocoders import Nominatim
>>> geolocator = Nominatim(user_agent="specify_your_app_name_here")
>>> location = geolocator.geocode("175 5th Avenue NYC")
>>> print(location.address)
Flatiron Building, 175, 5th Avenue, Flatiron, New York, NYC, New York, ...
>>> print((location.latitude, location.longitude))
(40.7410861, -73.9896297241625)
>>> print(location.raw)
{'place_id': '9167009604', 'type': 'attraction', ...}To find the address corresponding to a set of coordinates:
.. code:: pycon
>>> from geopy.geocoders import Nominatim
>>> geolocator = Nominatim(user_agent="specify_your_app_name_here")
>>> location = geolocator.reverse("52.509669, 13.376294")
>>> print(location.address)
Potsdamer Platz, Mitte, Berlin, 10117, Deutschland, European Union
>>> print((location.latitude, location.longitude))
(52.5094982, 13.3765983)
>>> print(location.raw)
{'place_id': '654513', 'osm_type': 'node', ...}Measuring Distance
------------------Geopy can calculate geodesic distance between two points using the
`geodesic distance
`_ or the
`great-circle distance
`_,
with a default of the geodesic distance available as the function
`geopy.distance.distance`.Here's an example usage of the geodesic distance, taking pair
of :code:`(lat, lon)` tuples:.. code:: pycon
>>> from geopy.distance import geodesic
>>> newport_ri = (41.49008, -71.312796)
>>> cleveland_oh = (41.499498, -81.695391)
>>> print(geodesic(newport_ri, cleveland_oh).miles)
538.390445368Using great-circle distance, also taking pair of :code:`(lat, lon)` tuples:
.. code:: pycon
>>> from geopy.distance import great_circle
>>> newport_ri = (41.49008, -71.312796)
>>> cleveland_oh = (41.499498, -81.695391)
>>> print(great_circle(newport_ri, cleveland_oh).miles)
536.997990696Documentation
-------------More documentation and examples can be found at
`Read the Docs `__.