好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > 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計算多幅圖像柵格值的平均值的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 91极品尤物国产在线播放| 把教授玩坏了| gogo全球专业高清摄影| 五月天丁香网| 国产精品无码欧美日韩AV红粉 | 少萝扒开秘?让男人桶爽| 亚洲视频区| 18禁裸体爆乳美女无遮挡视頻频 | 亚洲电影一区二区| 视频一区日韩| 精品999久久久久久中文字幕| 亚洲AⅤ欧美AⅤ综合AV小说| 欧美性猛交xxxx免费看| 高清欧美不卡一区二区三区| 日本高清www片| 绿帽社在线入口www免费| 用力挺入| 奶水公车| 激情图片小说| 欧美13一16sex性| 色欲98久久综合国产精品三区| 大奶h文| 91精品欧美成人| 久久免费特黄毛片| 美女班主任露出奶头喂我乳我| 337p粉嫩大胆色噜噜噜| 中国黄色一级毛片| 国产情侣久久精品| 在农村偷窥洗澡| 久久久噜噜噜久久网| 精品国产成人高清在线| 99国精产品一区二区三区A片| 中文字幕无码亚洲幕成a人蜜蜜| a级片免费观看| www一级黄色片| 韩国白衣女浴室门把手24| 会唱歌的大姐姐也想做| 久久99精品综合国产首页| 女を縄で缚っ紧缚| 亚洲天堂在线视频播放| 妈妈穿开裆裤让我cao她动漫 |