您好,登錄后才能下訂單哦!
最近要做個遙感相關的小系統,需要波段組合功能,網上找了可以使用ArcGIS安裝時自帶的arcpy包,但是Python3.7不能使用現有ArcGIS10.2版本,也不想再裝其他版本,所以只能自己想了個辦法解決。不過有點笨啊。
思路是:
1.讀取需要組合遙感影像波段(此處用OLI)
2.創建數組,把讀取的波段按序放進去
3.寫入文件,寫成tif多波段數據
上代碼:
from osgeo import gdal import os import numpy as np class GRID: #讀圖像文件 def read_img(self,filename): dataset=gdal.Open(filename) #打開文件 im_width = dataset.RasterXSize #柵格矩陣的列數 im_height = dataset.RasterYSize #柵格矩陣的行數 im_geotrans = dataset.GetGeoTransform() #仿射矩陣 im_proj = dataset.GetProjection() #地圖投影信息 im_data = dataset.ReadAsArray(0,0,im_width,im_height) #將數據寫成數組,對應柵格矩陣 del dataset #關閉對象,文件dataset return im_proj,im_geotrans,im_data,im_width,im_height #寫文件,以寫成tif為例 def write_img(self,filename,im_proj,im_geotrans,im_data): #判斷柵格數據的數據類型 if 'int8' in im_data.dtype.name: datatype = gdal.GDT_Byte elif 'int16' in im_data.dtype.name: datatype = gdal.GDT_UInt16 else: datatype = gdal.GDT_Float32 #判讀數組維數 if len(im_data.shape) == 3: im_bands, im_height, im_width = im_data.shape else: im_bands, (im_height, im_width) = 1,im_data.shape #創建文件 driver = gdal.GetDriverByName("GTiff") #數據類型必須有,因為要計算需要多大內存空間 dataset = driver.Create(filename, im_width, im_height, im_bands, datatype) dataset.SetGeoTransform(im_geotrans) #寫入仿射變換參數 dataset.SetProjection(im_proj) #寫入投影 if im_bands == 1: dataset.GetRasterBand(1).WriteArray(im_data) #寫入數組數據 else: for i in range(im_bands): dataset.GetRasterBand(i+1).WriteArray(im_data[i]) del dataset if __name__ == "__main__": os.chdir(r'E:\Python\temp\data') #切換路徑到待處理圖像所在文件夾 run = GRID() #第一步 proj,geotrans,data1,row1,column1 = run.read_img('Band_5_Clip.tif') #讀數據 proj,geotrans,data2,row2,column2= run.read_img('Band_4_Clip.tif') # 讀數據 proj,geotrans,data3,row3,column3 = run.read_img('Band_3_Clip.tif') # 讀數據 #第二步 data = np.array((data1, data2, data3),dtype = data1.dtype) #按序將3個波段像元值放入 #第三步 run.write_img('com543.tif', proj, geotrans, data) # 寫為3波段數據
OK!!和ArcGIS處理的對比一下,發現差別不大(上:ArcMap 下:Python)。
方法較笨,如果各位大神有更好的方法,我們可以私下交流交流。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。