Mam plik kształtu ESRI (tutaj: http://pubs.usgs.gov/ds/425/). Chciałbym użyć Pythona do wyszukiwania informacji z pliku kształtu (materiał powierzchniowy w tym przypadku) na danej szerokości/długości geograficznej.Jak używać Pythona do wyszukiwania informacji o określonej szerokości/długości geograficznej w pliku kształtu ESRI?
Jaki jest najlepszy sposób rozwiązania tego problemu?
Dzięki.
rozwiązanie końcowa:
#!/usr/bin/python
from osgeo import ogr, osr
dataset = ogr.Open('./USGS_DS_425_SHAPES/Surficial_materials.shp')
layer = dataset.GetLayerByIndex(0)
layer.ResetReading()
# Location for New Orleans: 29.98 N, -90.25 E
point = ogr.CreateGeometryFromWkt("POINT(-90.25 29.98)")
# Transform the point into the specified coordinate system from WGS84
spatialRef = osr.SpatialReference()
spatialRef.ImportFromEPSG(4326)
coordTransform = osr.CoordinateTransformation(
spatialRef, layer.GetSpatialRef())
point.Transform(coordTransform)
for feature in layer:
if feature.GetGeometryRef().Contains(point):
break
for i in range(feature.GetFieldCount()):
print feature.GetField(i)
Jeśli punkt nie znajduje się w żadnej z "cech", to ostatnie funkcje będą traktowane jako dopasowanie (i jego pola wydrukowane). Zadeklarowałbym oddzielną zmienną 'matched_feature' i przypisałam ją bezpośrednio przed' break', następnie użyłbym go do następnej pętli zamiast zmiennej 'feature' –