Skip to content

Instantly share code, notes, and snippets.

@alanorth
Created March 6, 2023 12:37
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 1 You must be signed in to fork a gist
  • Save alanorth/0cbebd89d19b74355bc33cd866cf2c07 to your computer and use it in GitHub Desktop.
Save alanorth/0cbebd89d19b74355bc33cd866cf2c07 to your computer and use it in GitHub Desktop.
Checking if GPS points are in a polygon with Shapely
#!/usr/bin/env python
#
# Given the three points below, this code prints:
#
# $ ~/src/geojson-test.py
# True
# True
# False
#
# Requires shapely to be installed in the virtual environment.
#
# See: https://stackoverflow.com/questions/20776205/point-in-polygon-with-geojson-in-python
import json
from shapely.geometry import Point
from shapely.geometry import Polygon
with open("/home/aorth/Downloads/kenya_gps.json", "r") as f:
kenya_json = json.load(f)
# lame way to get the Nairobi bounding box
for feature in kenya_json['features']:
if feature['id'] == 0:
nairobi_bounding_box = feature['geometry']['coordinates']
# The bounding box is a list of lists of points, so we have to unwrap the list with [0]
nairobi_polygon = Polygon(nairobi_bounding_box[0])
# Shapely points are apparently long/lat
cbd_point = Point(36.82052314069416, -1.2832858629766537)
ilri_point = Point(36.722035402975585, -1.2684044950804823)
nakuru_point = Point(36.44850230480384, -0.9135133124309164)
# See: https://shapely.readthedocs.io/en/stable/
print(nairobi_polygon.contains(cbd_point))
print(nairobi_polygon.contains(ilri_point))
print(nairobi_polygon.contains(nakuru_point))
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment