主頁(yè) > 知識(shí)庫(kù) > Python計(jì)算多幅圖像柵格值的平均值

Python計(jì)算多幅圖像柵格值的平均值

熱門(mén)標(biāo)簽:地圖標(biāo)注視頻廣告 梅州外呼業(yè)務(wù)系統(tǒng) 無(wú)錫客服外呼系統(tǒng)一般多少錢(qián) 洪澤縣地圖標(biāo)注 高德地圖標(biāo)注是免費(fèi)的嗎 百度地圖標(biāo)注位置怎么修改 老人電話機(jī)器人 大連crm外呼系統(tǒng) 北京電信外呼系統(tǒng)靠譜嗎

本文實(shí)例為大家分享了Python求多幅圖像柵格值的平均值,供大家參考,具體內(nèi)容如下

本程序所采用的方法并不是最優(yōu)方法,ARCGIS已經(jīng)提供了相關(guān)的函數(shù)供調(diào)用。本程序僅供參考。

程序說(shuō)明:

文件夾E://work//EVI_Data_tif中存放的是某地區(qū)2000-2010年的EVI圖像,其中每個(gè)年份共13幅。目的是將每年的13幅圖像的每個(gè)柵格相加求均值,生成相應(yīng)年份的tif。例如,將2000年的13幅圖像相加求均值生成2000.tif,里面的每個(gè)柵格的值就是13幅圖像對(duì)應(yīng)柵格值相加得到的均值。結(jié)果存放于E:\work\result。源文件組織方式為:以2000年為例,文件名依次為 20006.tif,20007.tif,20008.tif,……,200018.tif。

import os
import os.path
import gdal
import sys
from gdalconst import *
from osgeo import gdal
import osr
import numpy as np
#coding=utf-8

def WriteGTiffFile(filename, nRows, nCols, data,geotrans,proj, noDataValue, gdalType):#向磁盤(pán)寫(xiě)入結(jié)果文件
    format = "GTiff"   
    driver = gdal.GetDriverByName(format)
    ds = driver.Create(filename, nCols, nRows, 1, gdalType)
    ds.SetGeoTransform(geotrans)
    ds.SetProjection(proj)
    ds.GetRasterBand(1).SetNoDataValue(noDataValue)
    ds.GetRasterBand(1).WriteArray(data)    
    ds = None

def File():#遍歷文件,讀取數(shù)據(jù),算出均值
    rows,cols,geotransform,projection,noDataValue = Readxy('E://work//EVI_Data_tif//20006.tif')
    #獲取源文件的行,列,投影等信息,所有的源文件這些信息都是一致的
    print 'rows and cols is ',rows,cols
    filesum = [[0.0]*cols]*rows #柵格值和,二維數(shù)組
    average= [[0.0]*cols]*rows# 存放平均值,二維數(shù)組
    filesum=np.array(filesum)#轉(zhuǎn)換類(lèi)型為np.array
    average = np.array(average) 
    print 'the type of filesum',type(filesum)
    count=0
    rootdir = 'E:\work\EVI_Data_tif'
    for dirpath,filename,filenames in os.walk(rootdir):#遍歷源文件
        for filename in filenames:
            if os.path.splitext(filename)[1] == '.tif':#判斷是否為tif格式
                filepath = os.path.join(dirpath,filename)
                purename = filename.replace('.tif','') #獲得除去擴(kuò)展名的文件名,比如201013.tif,purename為201013               
                if purename[:4] == '2010':              #判斷年份
                    filedata = [[0.0]*cols]*rows
                    filedata = np.array(filedata)
                    filedata = Read(filepath)           #將2010年的13幅圖像數(shù)據(jù)存入filedata中
                    count+=1
                    np.add(filesum,filedata,filesum)    #求13幅圖像相應(yīng)柵格值的和
                    #print str(count)+'this is filedata',filedata
    print 'count is ',count    
    for i in range(0,rows):
        for j in range(0,cols):
            if(filesum[i,j]==noDataValue*count):        #處理圖像中的noData
                average[i,j]=-9999
            else: 
                average[i,j]=filesum[i,j]*1.0/count     #求平均
    WriteGTiffFile("E:\\work\\result\\2010.tif", rows, cols, average,geotransform,projection, -9999, GDT_Float32) #寫(xiě)入結(jié)果文件           

def Readxy(RasterFile): #讀取每個(gè)圖像的信息     
    ds = gdal.Open(RasterFile,GA_ReadOnly)
    if ds is None:
        print 'Cannot open ',RasterFile
        sys.exit(1)
    cols = ds.RasterXSize
    rows = ds.RasterYSize
    band = ds.GetRasterBand(1)
    data = band.ReadAsArray(0,0,cols,rows)
    noDataValue = band.GetNoDataValue()
    projection=ds.GetProjection()
    geotransform = ds.GetGeoTransform()
    return rows,cols,geotransform,projection,noDataValue

def Read(RasterFile):#讀取每個(gè)圖像的信息
    ds = gdal.Open(RasterFile,GA_ReadOnly)    
    if ds is None:
        print 'Cannot open ',RasterFile
        sys.exit(1)
    cols = ds.RasterXSize
    rows = ds.RasterYSize
    band = ds.GetRasterBand(1)
    data = band.ReadAsArray(0,0,cols,rows)  
    return data    
if __name__ == "__main__":
    print"ok1"
    File()   
    print"ok2"

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • 關(guān)于Python 的簡(jiǎn)單柵格圖像邊界提取方法
  • Python疊加兩幅柵格圖像的實(shí)現(xiàn)方法

標(biāo)簽:泉州 岳陽(yáng) 怒江 長(zhǎng)春 吉林 洛陽(yáng) 安慶 清遠(yuǎn)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Python計(jì)算多幅圖像柵格值的平均值》,本文關(guān)鍵詞  Python,計(jì)算,多幅,圖像,柵格,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Python計(jì)算多幅圖像柵格值的平均值》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于Python計(jì)算多幅圖像柵格值的平均值的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章