中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python 實現遙感影像波段組合的示例代碼

發布時間:2020-08-26 22:19:23 來源:腳本之家 閱讀:266 作者:改不了昵稱呀 欄目:開發技術

最近要做個遙感相關的小系統,需要波段組合功能,網上找了可以使用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)。

Python 實現遙感影像波段組合的示例代碼

Python 實現遙感影像波段組合的示例代碼

方法較笨,如果各位大神有更好的方法,我們可以私下交流交流。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

江城| 盐边县| 大邑县| 胶南市| 滨州市| 荥阳市| 金门县| 上蔡县| 石河子市| 大邑县| 抚远县| 庆安县| 南城县| 荣成市| 沂源县| 贡觉县| 汕头市| 明溪县| 读书| 云龙县| 缙云县| 车致| 习水县| 潜山县| 吉林市| 山东省| 从江县| 孙吴县| 陆丰市| 宣武区| 德清县| 宁南县| 芷江| 乡宁县| 铅山县| 咸丰县| 德格县| 新乐市| 沁源县| 大兴区| 通州区|