6. GDAL进行栅格转矢量
生活随笔
收集整理的這篇文章主要介紹了
6. GDAL进行栅格转矢量
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1 代碼實現
參考下面代碼實現
python 使用GDAL實現柵格tif轉矢量shp的方式小結_python_腳本之家
https://www.jb51.net/article/219157.htm
2 柵格轉矢量并刪除指定屬性的要素
from osgeo import gdal, ogr, osr import os import datetime import numpy as npdef raster_shp(path):inraster = gdal.Open(path) # 讀取路徑中的柵格數據inband = inraster.GetRasterBand(1) # 這個波段就是最后想要轉為矢量的波段,如果是單波段數據的話那就都是1prj = osr.SpatialReference()prj.ImportFromWkt(inraster.GetProjection()) # 讀取柵格數據的投影信息,用來為后面生成的矢量做準備outshp = path[:-4] + ".shp" # 給后面生成的矢量準備一個輸出文件名,這里就是把原柵格的文件名后綴名改成shp了drv = ogr.GetDriverByName("ESRI Shapefile")if os.path.exists(outshp): # 若文件已經存在,則刪除它繼續重新做一遍drv.DeleteDataSource(outshp)Polygon = drv.CreateDataSource(outshp) # 創建一個目標文件Poly_layer = Polygon.CreateLayer(path[:-4], srs=prj, geom_type=ogr.wkbMultiPolygon) # 對shp文件創建一個圖層,定義為多個面類newField = ogr.FieldDefn('value', ogr.OFTReal) # 給目標shp文件添加一個字段,用來存儲原始柵格的pixel value,浮點型,Poly_layer.CreateField(newField)gdal.Polygonize(inband, None, Poly_layer, 0) # 核心函數,執行的就是柵格轉矢量操作# gdal.FPolygonize(inband, None, Poly_layer, 0) # 只轉矩形,不合并Polygon.SyncToDisk()Polygon = Nonedef raster_shp_delete_0(path):inraster = gdal.Open(path) # 讀取路徑中的柵格數據inband = inraster.GetRasterBand(1) # 這個波段就是最后想要轉為矢量的波段,如果是單波段數據的話那就都是1prj = osr.SpatialReference()prj.ImportFromWkt(inraster.GetProjection()) # 讀取柵格數據的投影信息,用來為后面生成的矢量做準備outshp = path[:-4] + "d0.shp" # 給后面生成的矢量準備一個輸出文件名,這里就是把原柵格的文件名后綴名改成shp了drv = ogr.GetDriverByName("ESRI Shapefile")if os.path.exists(outshp): # 若文件已經存在,則刪除它繼續重新做一遍drv.DeleteDataSource(outshp)Polygon = drv.CreateDataSource(outshp) # 創建一個目標文件Poly_layer = Polygon.CreateLayer(path[:-4], srs=prj, geom_type=ogr.wkbMultiPolygon) # 對shp文件創建一個圖層,定義為多個面類newField = ogr.FieldDefn('value', ogr.OFTReal) # 給目標shp文件添加一個字段,用來存儲原始柵格的pixel value,浮點型,Poly_layer.CreateField(newField)gdal.Polygonize(inband, None, Poly_layer, 0) # 核心函數,執行的就是柵格轉矢量操作# gdal.FPolygonize(inband, None, Poly_layer, 0) # 只轉矩形,不合并strValue = 0strFilter = "Value = '" + str(strValue) + "'"Poly_layer.SetAttributeFilter(strFilter)pFeatureDef = Poly_layer.GetLayerDefn()pLayerName = Poly_layer.GetName()pFieldName = "Value"pFieldIndex = pFeatureDef.GetFieldIndex(pFieldName)for pFeature in Poly_layer:pFeatureFID = pFeature.GetFID()Poly_layer.DeleteFeature(int(pFeatureFID))strSQL = "REPACK " + str(Poly_layer.GetName())Polygon.ExecuteSQL(strSQL, None, "");Poly_layer = NonePolygon.SyncToDisk()Polygon = Noneif __name__ == '__main__':path = r"I:\5GF2\1ALLimg20211130\8波段4預測結果\GF7_DLC_E116.6_N31.1_20210911_L1A0000560021-BWDPAN_ORTHO_PSH_preR.tif"start_time = datetime.datetime.now()raster_shp_delete_0(path)end_time = datetime.datetime.now()print("Succeeded at", end_time)print("Elapsed Time:", end_time - start_time) # 輸出程序運行所需時間參考文獻:
看下面兩個就可以了
[1] 【Python】GDAL批量柵格轉矢量 - 知乎
https://zhuanlan.zhihu.com/p/210939809
[2] (39條消息) GDAL–柵格轉矢量_secyb的博客-CSDN博客_gdal柵格轉矢量
https://blog.csdn.net/secyb/article/details/80245157
【3】柵格結果不保存到磁盤中,Python ogr.GetDriverByName方法代碼示例 - 純淨天空
https://vimsky.com/zh-tw/examples/detail/python-method-osgeo.ogr.GetDriverByName.html
總結
以上是生活随笔為你收集整理的6. GDAL进行栅格转矢量的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 依赖倒置和控制反转
- 下一篇: Lindows来了,Windows咋办?