Geo routing for Python users, supporting most of the routing tools, including OSRM, Google Maps, Bing Maps, etc. with a unified API.
Warning!!! This project is under active development, wait for the release of version 1.0.0 if you want to use it in production. This package is inspired by geopy. Please help to improve this package by submitting issues and pull requests.
- Free software: MIT license
- Documentation: https://wybert.github.io/georouting
- Support most of the routing services, including Google Maps, Bing Maps, OSRM, etc.
- Provide a unified API for routing services
- Support calculating the travel distance matrix between multiple origins and destinations
- Support calculating the travel distance according to OD pairs.
- Easy to visualize the routing results
- Return the travel distance matrix in a Pandas
Dataframe
you like - Return the routing results in a Geopandas
GeoDataFrame
- Easy to extend to support more routing services
To install georouting, run this command in your terminal:
pip install georouting
or install from GitHub source
pip install git+https://github.com/wybert/georouting.git
If you don't have pip installed, this Python installation guide can guide you through the process.
conda install -c conda-forge georouting
or use mamba
mamba install -c conda-forge georouting
The sources for georouting can be downloaded from the Github repo.
You can clone the public repository:
git clone git://github.com/wybert/georouting
Then install it with:
python setup.py install
# how to get routing distance matrix from OSRMRouter
import pandas as pd
data = pd.read_csv("https://raw.githubusercontent.com/wybert/georouting/main/docs/data/sample_3.csv",index_col=0)
one_od_pair = data.iloc[2]
data.head()
from georouting.routers import GoogleRouter
# create a router object with the google_key
router = GoogleRouter(google_key,mode="driving")
# get the route between the origin and destination, this will return a Route object
# this will call the Google Maps API
route = router.get_route([one_od_pair["ZIP_lat"],one_od_pair["ZIP_lon"]],
[one_od_pair["AHA_ID_lat"],one_od_pair["AHA_ID_lon"]])
# Now you can get the distance and duration of the route in meters and seconds
print("Distance: {} meters".format(route.get_distance()))
print("Duration: {} seconds".format(route.get_duration()))
df= route.get_route_geopandas()
df.head()
df.explore(column="speed (m/s)",style_kwds={"weight":11,"opacity":0.8})
- Google Maps
- Bing Maps
- OSRM Routing
- add more documentation for google router
- add more documentation for bing router
- add more documentation for osrm router
- built and host documentation
- Fix the update in Pypi
- add get_route_distance_batch API
- add visualization for the route, better with o and d markers
- Limit the number of origins and destinations in the distance matrix
- avoid repeat documentation
- add ESRI router
- Add test
- Add more examples
- Add how to contribute
- change the show case use OSRM
- add OSMnx router
- add one API for all routers
- add extract graph data from osm data, easy way
- Add how to cite
This package was created with Cookiecutter and the giswqs/pypackage project template.