婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Python計算多幅圖像柵格值的平均值

Python計算多幅圖像柵格值的平均值

熱門標簽:地圖標注視頻廣告 梅州外呼業務系統 無錫客服外呼系統一般多少錢 洪澤縣地圖標注 高德地圖標注是免費的嗎 百度地圖標注位置怎么修改 老人電話機器人 大連crm外呼系統 北京電信外呼系統靠譜嗎

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

本程序所采用的方法并不是最優方法,ARCGIS已經提供了相關的函數供調用。本程序僅供參考。

程序說明:

文件夾E://work//EVI_Data_tif中存放的是某地區2000-2010年的EVI圖像,其中每個年份共13幅。目的是將每年的13幅圖像的每個柵格相加求均值,生成相應年份的tif。例如,將2000年的13幅圖像相加求均值生成2000.tif,里面的每個柵格的值就是13幅圖像對應柵格值相加得到的均值。結果存放于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):#向磁盤寫入結果文件
    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():#遍歷文件,讀取數據,算出均值
    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 #柵格值和,二維數組
    average= [[0.0]*cols]*rows# 存放平均值,二維數組
    filesum=np.array(filesum)#轉換類型為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','') #獲得除去擴展名的文件名,比如201013.tif,purename為201013               
                if purename[:4] == '2010':              #判斷年份
                    filedata = [[0.0]*cols]*rows
                    filedata = np.array(filedata)
                    filedata = Read(filepath)           #將2010年的13幅圖像數據存入filedata中
                    count+=1
                    np.add(filesum,filedata,filesum)    #求13幅圖像相應柵格值的和
                    #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) #寫入結果文件           

def Readxy(RasterFile): #讀取每個圖像的信息     
    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):#讀取每個圖像的信息
    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"

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

您可能感興趣的文章:
  • 關于Python 的簡單柵格圖像邊界提取方法
  • Python疊加兩幅柵格圖像的實現方法

標簽:泉州 岳陽 怒江 長春 吉林 洛陽 安慶 清遠

巨人網絡通訊聲明:本文標題《Python計算多幅圖像柵格值的平均值》,本文關鍵詞  Python,計算,多幅,圖像,柵格,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Python計算多幅圖像柵格值的平均值》相關的同類信息!
  • 本頁收集關于Python計算多幅圖像柵格值的平均值的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 长垣县| 昭平县| 凤冈县| 彭山县| 广汉市| 石嘴山市| 微山县| 峨山| 河间市| 石楼县| 顺平县| 高淳县| 长汀县| 玉田县| 浠水县| 吉隆县| 邹平县| 共和县| 金溪县| 班玛县| 象山县| 项城市| 页游| 同江市| 林周县| 平安县| 息烽县| 建昌县| 中江县| 肥城市| 庐江县| 内丘县| 扬州市| 红桥区| 白水县| 石泉县| 曲阳县| 闽侯县| 周口市| 玉环县| 潍坊市|