У меня есть шейп-файл ESRI (отсюда: http://pubs.usgs.gov/ds/425/< /а>). Я хочу использовать python для поиска информации из файла формы (в данном случае поверхностного материала) на заданной широте/долготе.
Каков наилучший способ решить эту проблему?
Спасибо.
Окончательное решение:
#!/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)
features
, то последние объекты будут считаться совпадением (и будут напечатаны его поля). Я бы объявил отдельную переменнуюmatched_feature
и присвоил ей значение непосредственно передbreak
, а затем использовал ее для следующего цикла вместо переменнойfeature
- person Simon Ndunda   schedule 25.09.2017