Esistono molti moduli per leggere shapefile in Python, più vecchi di ArcPy, guarda l' indice dei pacchetti Python (PyPi): shapefile . Ci sono anche molti esempi in GIS SE (cercare [Python] Fiona , per esempio)
Tutti possono leggere la geometria, i campi e le proiezioni.
Ma altri moduli come PySAL: la Python Spatial Analysis Library , Cartopy (che usano pyshp ) o Matplotlib Basemap possono anche leggere shapefile, tra le altre cose.
Il più semplice da usare è Fiona , ma se conosci solo ArcPy, usa pyshp , poiché osgeo e Fiona richiedono l' installazione della libreria GDAL C / C ++, GeoPandas necessita del modulo Pandas e PySAL è troppo grande (molti, molti altri trattamenti)
Se vuoi solo leggere il contenuto di uno shapefile, non hai bisogno di cose complesse, usa semplicemente il protocollo di interfaccia geo (GeoJSON) implementato anche in ArcPy ( ArcPy: AsShape )
Con Fiona (come dizionari Python):
import fiona
with fiona.open('a_shape.shp') as shp:
# schema of the shapefile
print shp.schema
{'geometry': 'Point', 'properties': OrderedDict([(u'DIP', 'int:2'), (u'DIP_DIR', 'int:3'), (u'TYPE', 'str:10')])}
# projection
print shp.crs
{u'lon_0': 4.367486666666666, u'ellps': u'intl', u'y_0': 5400088.438, u'no_defs': True, u'proj': u'lcc', u'x_0': 150000.013, u'units': u'm', u'lat_2': 49.8333339, u'lat_1': 51.16666723333333, u'lat_0': 90}
for feature in shp:
print feature
{'geometry': {'type': 'Point', 'coordinates': (272070.600041, 155389.38792)}, 'type': 'Feature', 'id': '0', 'properties': OrderedDict([(u'DIP', 30), (u'DIP_DIR', 130), (u'TYPE', u'incl')])}
{'geometry': {'type': 'Point', 'coordinates': (271066.032148, 154475.631377)}, 'type': 'Feature', 'id': '1', 'properties': OrderedDict([(u'DIP', 55), (u'DIP_DIR', 145), (u'TYPE', u'incl')])}
{'geometry': {'type': 'Point', 'coordinates': (273481.498868, 153923.492988)}, 'type': 'Feature', 'id': '2', 'properties': OrderedDict([(u'DIP', 40), (u'DIP_DIR', 155), (u'TYPE', u'incl')])}
Con pyshp (come dizionari Python)
import shapefile
reader= shapefile.Reader("a_shape.shp")
# schema of the shapefile
print dict((d[0],d[1:]) for d in reader.fields[1:])
{'DIP_DIR': ['N', 3, 0], 'DIP': ['N', 2, 0], 'TYPE': ['C', 10, 0]}
fields = [field[0] for field in reader.fields[1:]]
for feature in reader.shapeRecords():
geom = feature.shape.__geo_interface__
atr = dict(zip(fields, feature.record))
print geom, atr
{'type': 'Point', 'coordinates': (272070.600041, 155389.38792)} {'DIP_DIR': 130, 'DIP': 30, 'TYPE': 'incl'}
{'type': 'Point', 'coordinates': (271066.032148, 154475.631377)} {'DIP_DIR': 145, 'DIP': 55, 'TYPE': 'incl'}
{'type': 'Point', 'coordinates': (273481.498868, 153923.492988)} {'DIP_DIR': 155, 'DIP': 40, 'TYPE': 'incl'}
Con osgeo / ogr (come dizionari Python)
from osgeo import ogr
reader = ogr.Open("a_shape.shp")
layer = reader.GetLayer(0)
for i in range(layer.GetFeatureCount()):
feature = layer.GetFeature(i)
print feature.ExportToJson()
{"geometry": {"type": "Point", "coordinates": [272070.60004, 155389.38792]}, "type": "Feature", "properties": {"DIP_DIR": 130, "DIP": 30, "TYPE": "incl"}, "id": 0}
{"geometry": {"type": "Point", "coordinates": [271066.032148, 154475.631377]}, "type": "Feature", "properties": {"DIP_DIR": 145, "DIP": 55, "TYPE": "incl"}, "id": 1}
{"geometry": {"type": "Point", "coordinates": [273481.49887, 153923.492988]}, "type": "Feature", "properties": {"DIP_DIR": 155, "DIP": 40, "TYPE": "incl"}, "id": 2}
Con GeoPandas (come dataframe Pandas)
import geopandas as gp
shp = gp.GeoDataFrame.from_file('a_shape.shp')
print shp
DIP_DIR DIP TYPE geometry
0 130 30 incl POINT (272070.600041 155389.38792)
1 145 55 incl POINT (271066.032148 154475.631377)
2 155 40 incl POINT (273481.498868 153923.492988)
* nota su geopandas Devi usare versioni precedenti di Fiona e GDAL con esso o non si installerà. GDAL: 1.11.2 Fiona: 1.6.0 Geopandas: 0.1.0.dev-
Esistono molti tutorial sul Web e persino libri ( Python Geospatial Development , Learning Geospatial Analysis con Python e Geoprocessing con Python , in corso di stampa)
Più in generale, se vuoi usare Python senza ArcPy, guarda la semplice mappatura tematica di shapefile usando Python?