Marshmallow schema validation for GeoJson
Project description
marshmallow_geojson 🌍
GeoJSON Objects |
Status |
---|---|
✅ |
|
✅ |
|
✅ |
|
✅ |
|
✅ |
|
✅ |
|
❌ |
|
❌ |
|
❌ |
Installation
marshmallow_geojson is compatible with Python 3.7 and 3.8. The recommended way to install is via poetry:
poetry add marshmallow_geojson
Using pip to install is also possible.
pip install marshmallow_geojson
GEOJSON
GeoJSON is a format for encoding a variety of geographic data structures.
{
"type": "Feature",
"geometry": {
"type": "Point",
"coordinates": [125.6, 10.1]
},
"properties": {
"name": "Dinagat Islands"
}
}
GeoJSON supports the following geometry types: Point, LineString, Polygon, MultiPoint, MultiLineString, and MultiPolygon. Geometric objects with additional properties are Feature objects. Sets of features are contained by FeatureCollection objects.
Point
Simple example data:
>>> from marshmallow_geojson import GeoJSONSchema
>>> data_string = '{"type": "Point","coordinates": [-105.01621, 39.57422]}'
>>> geojson_schema = GeoJSONSchema()
>>> geojson_schema.loads(geojson_text)
{'type': 'Point', 'coordinates': (-105.01621, 39.57422)}
MultiPoint
Simple example data:
>>> from marshmallow_geojson import GeoJSONSchema
>>> data_string = '{"type": "MultiPoint", "coordinates": [ [-105.01621, 39.57422], [-80.666513, 35.053994] ]}'
>>> geojson_schema = GeoJSONSchema()
>>> geojson_schema.loads(geojson_text)
{'type': 'MultiPoint', 'coordinates': [(-105.01621, 39.57422), (-80.666513, 35.053994)]}
LineString
Simple example data:
>>> from marshmallow_geojson import GeoJSONSchema
>>> data_string = '{"type": "LineString", "coordinates": [ [-99.113159, 38.869651], [-99.0802, 38.85682], [-98.822021, 38.85682], [-98.448486, 38.848264] ]}'
>>> geojson_schema = GeoJSONSchema()
>>> geojson_schema.loads(geojson_text)
{'type': 'LineString', 'coordinates': [(-99.113159, 38.869651), (-99.0802, 38.85682), (-98.822021, 38.85682), (-98.448486, 38.848264)]}
MultiLineString
Simple example data:
>>> from marshmallow_geojson import GeoJSONSchema
>>> data_string = '{"type": "MultiLineString", "coordinates": [ [ [-105.019898, 39.574997], [-105.019598, 39.574898], [-105.019061, 39.574782] ], [ [-105.017173, 39.574402], [-105.01698, 39.574385], [-105.016636, 39.574385], [-105.016508, 39.574402], [-105.01595, 39.57427] ], [ [-105.014276, 39.573972], [-105.014126, 39.574038], [-105.013825, 39.57417], [-105.01331, 39.574452] ] ]}'
>>> geojson_schema = GeoJSONSchema()
>>> geojson_schema.loads(geojson_text)
{'type': 'MultiLineString', 'coordinates': [[(-105.019898, 39.574997), (-105.019598, 39.574898), (-105.019061, 39.574782)], [(-105.017173, 39.574402), (-105.01698, 39.574385), (-105.016636, 39.574385), (-105.016508, 39.574402), (-105.01595, 39.57427)], [(-105.014276, 39.573972), (-105.014126, 39.574038), (-105.013825, 39.57417), (-105.01331, 39.574452)]]}
Polygon
Simple example data:
>>> from marshmallow_geojson import GeoJSONSchema
>>> data_string = '{"type": "Polygon", "coordinates": [ [ [100, 0], [101, 0], [101, 1], [100, 1], [100, 0] ] ]}'
>>> geojson_schema = GeoJSONSchema()
>>> geojson_schema.loads(geojson_text)
{'type': 'Polygon', 'coordinates': [[(100.0, 0.0), (101.0, 0.0), (101.0, 1.0), (100.0, 1.0), (100.0, 0.0)]]}
MultiPolygon
Simple example data:
>>> from marshmallow_geojson import GeoJSONSchema
>>> data_string = '{"type": "MultiPolygon", "coordinates": [ [ [ [107, 7], [108, 7], [108, 8], [107, 8], [107, 7] ] ], [ [ [100, 0], [101, 0], [101, 1], [100, 1], [100, 0] ] ] ]}'
>>> geojson_schema = GeoJSONSchema()
>>> geojson_schema.loads(geojson_text)
{'type': 'MultiPolygon', 'coordinates': [[[(107.0, 7.0), (108.0, 7.0), (108.0, 8.0), (107.0, 8.0), (107.0, 7.0)]], [[(100.0, 0.0), (101.0, 0.0), (101.0, 1.0), (100.0, 1.0), (100.0, 0.0)]]]}
GeometryCollection
Simple example data:
{
"type": "GeometryCollection",
"geometries": [
{
"type": "Point",
"coordinates": [
-80.660805,
35.049392
]
},
{
"type": "Polygon",
"coordinates": [
[
[
-80.664582,
35.044965
],
[
-80.663874,
35.04428
],
[
-80.662586,
35.04558
],
[
-80.663444,
35.046036
],
[
-80.664582,
35.044965
]
]
]
},
{
"type": "LineString",
"coordinates": [
[
-80.662372,
35.059509
],
[
-80.662693,
35.059263
],
[
-80.662844,
35.05893
]
]
}
]
}
Feature
Simple example data:
{
"type": "Feature",
"geometry": {
"type": "Polygon",
"coordinates": [
[
[
-80.724878,
35.265454
],
[
-80.722646,
35.260338
],
[
-80.720329,
35.260618
],
[
-80.71681,
35.255361
],
[
-80.704793,
35.268397
],
[
-80.715179,
35.267696
],
[
-80.721359,
35.267276
],
[
-80.724878,
35.265454
]
]
]
},
"properties": {
"name": "Plaza Road Park"
}
}
FeatureCollection
Simple example data:
{
"type": "FeatureCollection",
"features": [
{
"type": "Feature",
"geometry": {
"type": "Point",
"coordinates": [
-80.870885,
35.215151
]
},
"properties": {
"name": "ABBOTT NEIGHBORHOOD PARK",
"address": "1300 SPRUCE ST"
}
},
{
"type": "Feature",
"geometry": {
"type": "Polygon",
"coordinates": [
[
[
-80.724878,
35.265454
],
[
-80.722646,
35.260338
],
[
-80.720329,
35.260618
],
[
-80.704793,
35.268397
],
[
-80.724878,
35.265454
]
]
]
},
"properties": {
"name": "Plaza Road Park"
}
}
]
}
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
Built Distribution
Hashes for marshmallow_geojson-0.1.17.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6132b632244fe8ba20d1e46b63788e6d9aac48ffdbc252cce7ac440b3c1386c7 |
|
MD5 | eb1059ebcbe9eb22fcee144b6b46a591 |
|
BLAKE2b-256 | cf09d656fe6a2136a6839523e2de67c1b72471033ded390dd1acee66ef92d9ab |
Hashes for marshmallow_geojson-0.1.17-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1fd8c0539ed1d1242cec3368733ede5e025477f6a383cfd2ebdf272ed8a2faad |
|
MD5 | 414c3483cb5200fdb14a8fbc2fd4fab2 |
|
BLAKE2b-256 | d7b101f20a4b28dd7b11941283c24b8ab11cdda622f74ad5619fea0c57e072af |