Python 實(shí)現(xiàn)遙感影像波段組合的示例代碼
最近要做個遙感相關(guān)的小系統(tǒng),需要波段組合功能,網(wǎng)上找了可以使用ArcGIS安裝時自帶的arcpy包,但是Python3.7不能使用現(xiàn)有ArcGIS10.2版本,也不想再裝其他版本,所以只能自己想了個辦法解決。不過有點(diǎn)笨啊。
思路是:
1.讀取需要組合遙感影像波段(此處用OLI)
2.創(chuàng)建數(shù)組,把讀取的波段按序放進(jìn)去
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ù)組,對應(yīng)柵格矩陣
del dataset #關(guān)閉對象,文件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ù)類型必須有,因?yàn)橐嬎阈枰啻髢?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)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python實(shí)現(xiàn)簡單點(diǎn)對點(diǎn)(p2p)聊天
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)簡單點(diǎn)對點(diǎn)p2p聊天,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-09-09
Python 使用PIL numpy 實(shí)現(xiàn)拼接圖片的示例
今天小編就為大家分享一篇Python 使用PIL numpy 實(shí)現(xiàn)拼接圖片的示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-05-05
Pycharm配置遠(yuǎn)程SSH服務(wù)器實(shí)現(xiàn)(切換不同虛擬環(huán)境)
本文主要介紹了Pycharm配置遠(yuǎn)程SSH服務(wù)器實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-02-02
python打包exe文件并隱藏執(zhí)行CMD命令窗口問題
這篇文章主要介紹了python打包exe文件并隱藏執(zhí)行CMD命令窗口問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-01-01

