python的ogr模块_使用GDAL/OGR python模块解析osm.pbf数据

感谢scai的回答,我弄明白了。

在gdal.org/1.11/ogr/drv_osm.html中提到的交错阅读所需的特殊阅读模式被翻译成了一个可以在下面找到的工作python示例。

这是如何提取在.osm.pbf文件中有“市容=酒馆”标签

import gdal, ogr

gdal.SetConfigOption('OGR_INTERLEAVED_READING', 'YES')

osm = ogr.Open('file.osm.pbf')

# Grab available layers in file

nLayerCount = osm.GetLayerCount()

thereIsDataInLayer = True

pubs = []

while thereIsDataInLayer:

thereIsDataInLayer = False

# Cycle through available layers

for iLayer in xrange(nLayerCount):

lyr=osm.GetLayer(iLayer)

# Get first feature from layer

feat = lyr.GetNextFeature()

while (feat is not None):

thereIsDataInLayer = True

#Do something with feature, in this case store them in a list

if feat.GetField('amenity') == 'pub':

pubs.append(feat)

#The destroy method is necessary for interleaved reading

feat.Destroy()

feat = lyr.GetNextFeature()

据我了解它的所有功能为例,需要一个while循环而不是一个for-loop,因为当使用交错读取方法时,不可能获得集合的特征计数。

更多关于这段代码为什么能起作用的原因将不胜感激。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python中,可以使用OGR/GDAL库来确定shapefile和栅格是否重叠。具体步骤如下: 1. 导入必要的库 ```python from osgeo import ogr, gdal ``` 2. 打开shapefile,并获取其空间参考 ```python shapefile = ogr.Open("path/to/shapefile.shp") layer = shapefile.GetLayer() spatialRef = layer.GetSpatialRef() ``` 3. 打开栅格文件,并获取其空间参考和变换矩阵 ```python rasterfile = gdal.Open("path/to/rasterfile.tif") geotransform = rasterfile.GetGeoTransform() spatialRef = rasterfile.GetProjection() ``` 4. 将shapefile的空间参考和栅格的空间参考进行比较 ```python if spatialRef == layer.GetSpatialRef().ExportToWkt(): print("The shapefile and raster have the same spatial reference.") else: print("The shapefile and raster have different spatial references.") ``` 5. 获取shapefile的范围,并将其转换为栅格坐标系中的范围 ```python # 获取shapefile的范围 extent = layer.GetExtent() # 将shapefile的范围转换为栅格坐标系中的范围 ulx, uly = gdal.ApplyGeoTransform(geotransform, extent[0], extent[3]) lrx, lry = gdal.ApplyGeoTransform(geotransform, extent[1], extent[2]) ``` 6. 获取栅格的范围 ```python xsize = rasterfile.RasterXSize ysize = rasterfile.RasterYSize x_min = geotransform[0] y_max = geotransform[3] x_max = x_min + geotransform[1] * xsize y_min = y_max + geotransform[5] * ysize ``` 7. 判断shapefile和栅格是否重叠 ```python if ulx < x_max and lrx > x_min and uly > y_min and lry < y_max: print("The shapefile and raster overlap.") else: print("The shapefile and raster do not overlap.") ``` 注意,上述代码中的shapefile和rasterfile的路径需要根据实际情况进行修改。另外,由于shapefile和栅格的范围可能不完全重合,因此上述代码中的重叠判断是基于两者的边界框进行的。如果需要更精确的重叠判断,可以使用更复杂的方法,例如将栅格转换为矢量数据,然后进行空间分析。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值