Skip to main content

Geocoder is a simple and consistent geocoding library.

Project description

https://img.shields.io/pypi/v/geocoder.svg https://img.shields.io/pypi/dm/geocoder.svg https://travis-ci.org/DenisCarriere/geocoder.svg?branch=master https://coveralls.io/repos/DenisCarriere/geocoder/badge.svg?branch=master&service=github

Simple and consistent geocoding library written in Python.

Many online providers such as Google & Bing have geocoding services, these providers do not include Python libraries and have different JSON responses between each other.

It can be very difficult sometimes to parse a particular geocoding provider since each one of them have their own JSON schema.

Here is a typical example of retrieving a Lat & Lng from Google using Python, things shouldn’t be this hard.

>>> import requests
>>> url = 'https://maps.googleapis.com/maps/api/geocode/json'
>>> params = {'sensor': 'false', 'address': 'Mountain View, CA'}
>>> r = requests.get(url, params=params)
>>> results = r.json()['results']
>>> location = results[0]['geometry']['location']
>>> location['lat'], location['lng']
(37.3860517, -122.0838511)

Now lets use Geocoder to do the same task.

>>> import geocoder
>>> g = geocoder.google('Mountain View, CA')
>>> g.latlng
(37.3860517, -122.0838511)

API Overview

Many properties are available once the geocoder object is created.

Forward

>>> import geocoder
>>> g = geocoder.google('Mountain View, CA')
>>> g.geojson
>>> g.json
>>> g.wkt
>>> g.osm
...

Reverse

>>> g = geocoder.google([45.15, -75.14], method='reverse')
>>> g.city
>>> g.state
>>> g.state_long
>>> g.country
>>> g.country_long
...

House Addresses

>>> g = geocoder.google("453 Booth Street, Ottawa ON")
>>> g.housenumber
>>> g.postal
>>> g.street
>>> g.street_long
...

IP Addresses

>>> import geocoder
>>> g = geocoder.ip('199.7.157.0')
>>> g = geocoder.ip('me')
>>> g.latlng
>>> g.city

Command Line Interface

$ geocode "Ottawa, ON"  >> ottawa.geojson
$ geocode "Ottawa, ON" \
    --provide google \
    --out geojson \
    --method geocode

Providers

Provider

Optimal

Access

ArcGIS

World

Baidu

China

API key

Bing

World

API key

CanadaPost

Canada

API key

FreeGeoIP

World

Geocoder.ca

North America

Rate Limit

GeoNames

World

Username

GeoOttawa

Ottawa

Google

World

Rate Limit

HERE

World

API key

IPInfo

World

Mapbox

World

API key

MapQuest

World

API key

MaxMind

World

OpenCage

World

API key

OpenStreetMap

World

TomTom

World

API key

What3Words

World

API key

Yahoo

World

Yandex

Russia

Installation

PyPi Install

To install Geocoder, simply:

$ pip install geocoder

GitHub Install

Installing the latest version from Github:

$ git clone https://github.com/DenisCarriere/geocoder
$ cd geocoder
$ python setup.py install

Documentation

https://geocoder.readthedocs.org/

Twitter

Speak up on Twitter DenisCarriere and tell me how you use this Python Geocoder. New updates will be pushed to Twitter Hashtags python.

Topic not available?

If you cannot find a topic you are looking for, please feel free to ask me DenisCarriere or post them on the Github Issues Page.

Feedback

Please feel free to give any feedback on this module. If you find any bugs or any enhancements to recommend please send some of your comments/suggestions to the Github Issues Page.

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

geocoder-1.8.0.tar.gz (33.6 kB view details)

Uploaded Source

Built Distribution

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

geocoder-1.8.0-py2.py3-none-any.whl (154.2 kB view details)

Uploaded Python 2Python 3

File details

Details for the file geocoder-1.8.0.tar.gz.

File metadata

  • Download URL: geocoder-1.8.0.tar.gz
  • Upload date:
  • Size: 33.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for geocoder-1.8.0.tar.gz
Algorithm Hash digest
SHA256 82b00a043cb227243e057d2ffe187cd828f8c568c7e144b8301c5e5dca9c5edd
MD5 c5023663038c5a540a6ab4d93097f7c6
BLAKE2b-256 8f0fd8b3879560f68fe56d7c0a4564a3c521617838ef27d8caf04cb3dc76c030

See more details on using hashes here.

File details

Details for the file geocoder-1.8.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for geocoder-1.8.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 b0c7464d389ef8b0dc74a4dd2ec1e984af1959cf8b3608b8d616aa3fbe121542
MD5 24c6b6da3591b730c01de8429e5d82ce
BLAKE2b-256 02042fc6013172d1c6f96340b1754f673657690ada634979c4f76ad3c24454c2

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