亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python 實現(xiàn)遙感影像波段組合的示例代碼

 更新時間:2019年08月04日 10:46:02   作者:改不了昵稱呀  
這篇文章主要介紹了Python 實現(xiàn)遙感影像波段組合的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

最近要做個遙感相關的小系統(tǒng),需要波段組合功能,網(wǎng)上找了可以使用ArcGIS安裝時自帶的arcpy包,但是Python3.7不能使用現(xiàn)有ArcGIS10.2版本,也不想再裝其他版本,所以只能自己想了個辦法解決。不過有點笨啊。

思路是:

1.讀取需要組合遙感影像波段(此處用OLI)  

2.創(chuàng)建數(shù)組,把讀取的波段按序放進去  

3.寫入文件,寫成tif多波段數(shù)據(jù)

上代碼:

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  #柵格矩陣的列數(shù)
    im_height = dataset.RasterYSize  #柵格矩陣的行數(shù)
 
    im_geotrans = dataset.GetGeoTransform() #仿射矩陣
    im_proj = dataset.GetProjection() #地圖投影信息
    im_data = dataset.ReadAsArray(0,0,im_width,im_height) #將數(shù)據(jù)寫成數(shù)組,對應柵格矩陣
 
    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):
 
    #判斷柵格數(shù)據(jù)的數(shù)據(jù)類型
    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
 
    #判讀數(shù)組維數(shù)
    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
 
    #創(chuàng)建文件
    driver = gdal.GetDriverByName("GTiff")  #數(shù)據(jù)類型必須有,因為要計算需要多大內(nèi)存空間
    dataset = driver.Create(filename, im_width, im_height, im_bands, datatype)
 
    dataset.SetGeoTransform(im_geotrans)       #寫入仿射變換參數(shù)
    dataset.SetProjection(im_proj)          #寫入投影
 
    if im_bands == 1:
      dataset.GetRasterBand(1).WriteArray(im_data) #寫入數(shù)組數(shù)據(jù)
    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') #讀數(shù)據(jù)
  proj,geotrans,data2,row2,column2= run.read_img('Band_4_Clip.tif') # 讀數(shù)據(jù)
  proj,geotrans,data3,row3,column3 = run.read_img('Band_3_Clip.tif') # 讀數(shù)據(jù)
 
  #第二步
  data = np.array((data1, data2, data3),dtype = data1.dtype) #按序?qū)?個波段像元值放入
 
  #第三步
  run.write_img('com543.tif', proj, geotrans, data) # 寫為3波段數(shù)據(jù)

OK?。『虯rcGIS處理的對比一下,發(fā)現(xiàn)差別不大(上:ArcMap   下:Python)。

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

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • Python中使用partial改變方法默認參數(shù)實例

    Python中使用partial改變方法默認參數(shù)實例

    這篇文章主要介紹了Python中使用partial改變方法默認參數(shù)實例,本文直接給出使用實例,代碼中包含詳細注釋,需要的朋友可以參考下
    2015-04-04
  • Python游戲開發(fā)之精靈和精靈組

    Python游戲開發(fā)之精靈和精靈組

    python作為當前非常受歡迎的編程語言,很大一部分原因是擁有豐富的庫,這篇文章主要給大家介紹了關于Python游戲開發(fā)之精靈和精靈組的相關資料,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2023-05-05
  • Python?調(diào)用GPT-3?API實現(xiàn)過程詳解

    Python?調(diào)用GPT-3?API實現(xiàn)過程詳解

    這篇文章主要為大家介紹了Python?調(diào)用GPT-3?API實現(xiàn)過程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-02-02
  • Python與Node.js之間實現(xiàn)通信的JSON數(shù)據(jù)接收發(fā)送

    Python與Node.js之間實現(xiàn)通信的JSON數(shù)據(jù)接收發(fā)送

    Python和Node.js是兩個流行且功能強大的編程語言,它們之間使用JSON格式進行數(shù)據(jù)交換是一種高效和靈活的方式,本文將詳細介紹如何在Python和Node.js之間通過JSON進行數(shù)據(jù)通信,包括發(fā)送和接收JSON數(shù)據(jù)以及一些常見的交互示例代碼
    2024-01-01
  • 在Django中實現(xiàn)添加user到group并查看

    在Django中實現(xiàn)添加user到group并查看

    今天小編就為大家分享一篇在Django中實現(xiàn)添加user到group并查看,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • Python使用Keras OCR實現(xiàn)從圖像中刪除文本

    Python使用Keras OCR實現(xiàn)從圖像中刪除文本

    這篇文章主要為大家介紹了如何在Python中利用Keras OCR實現(xiàn)快速地從圖像中刪除文本,從而作為圖像分類器的預處理步驟,需要的可以參考一下
    2022-03-03
  • 三個520專屬Python表白代碼分享

    三個520專屬Python表白代碼分享

    快到520了,這篇文章主要為大家介紹了三個520專屬Python表白代碼。文中的示例代碼講解詳細,感興趣的小伙伴快跟隨小編一起動手試一試
    2022-05-05
  • 利用Python計算圓周率π的實例代碼

    利用Python計算圓周率π的實例代碼

    圓周率沒有精確的計算公式,所以只能用近似的方式計算它的近似值。這篇文章主要介紹了利用Python計算圓周率π的相關資料,需要的朋友可以參考下
    2021-05-05
  • 基于python socketserver框架全面解析

    基于python socketserver框架全面解析

    下面小編就為大家?guī)硪黄趐ython socketserver框架全面解析。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • Python 線程池用法簡單示例

    Python 線程池用法簡單示例

    這篇文章主要介紹了Python 線程池用法,結(jié)合簡單實例形式分析了Python線程池相關使用技巧與操作注意事項,需要的朋友可以參考下
    2019-10-10

最新評論