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

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

 更新時間:2021年06月18日 17:19:34   作者:hnyzwtf  
這篇文章主要為大家詳細介紹了Python計算多幅圖像柵格值的平均值,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

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

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

程序說明:

文件夾E://work//EVI_Data_tif中存放的是某地區(qū)2000-2010年的EVI圖像,其中每個年份共13幅。目的是將每年的13幅圖像的每個柵格相加求均值,生成相應(yīng)年份的tif。例如,將2000年的13幅圖像相加求均值生成2000.tif,里面的每個柵格的值就是13幅圖像對應(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):#向磁盤寫入結(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)換類型為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幅圖像數(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) #寫入結(jié)果文件           

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"

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

相關(guān)文章

  • Python編程中如何捕獲警告ps不是捕獲異常

    Python編程中如何捕獲警告ps不是捕獲異常

    這篇文章主要為大家介紹了如何使用Python捕獲警告,注意:不是捕獲異常哦,有需要的朋友可以借鑒參考下,希望能夠有所幫助祝大家多多進步
    2021-10-10
  • Python雙版本計算器詳解

    Python雙版本計算器詳解

    這篇文章主要介紹了如何用Python制作計算器,文章中有兩個版本,代碼詳細,適合絕大部分朋友,如果你對python如何制作計算器有興趣,可以參考下這篇文章
    2021-04-04
  • Python自動化測試Eclipse+Pydev 搭建開發(fā)環(huán)境

    Python自動化測試Eclipse+Pydev 搭建開發(fā)環(huán)境

    本文主要介紹python自動化測試環(huán)境搭建,這里對Eclipse+Pydev 搭建開發(fā)環(huán)境做了圖文詳解,有需要的小伙伴可以參考下
    2016-08-08
  • python爬蟲之代理ip正確使用方法實例

    python爬蟲之代理ip正確使用方法實例

    在爬蟲的過程中,我們經(jīng)常會遇見很多網(wǎng)站采取了防爬蟲技術(shù),或者說因為自己采集網(wǎng)站信息的強度和采集速度太大,給對方服務(wù)器帶去了太多的壓力,下面這篇文章主要給大家介紹了關(guān)于python爬蟲之代理ip正確使用方法的相關(guān)資料,需要的朋友可以參考下
    2022-07-07
  • 使用Python opencv實現(xiàn)視頻與圖片的相互轉(zhuǎn)換

    使用Python opencv實現(xiàn)視頻與圖片的相互轉(zhuǎn)換

    這篇文章主要介紹了使用Python opencv實現(xiàn)視頻與圖片的相互轉(zhuǎn)換,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-07-07
  • 完美解決python中ndarray 默認用科學(xué)計數(shù)法顯示的問題

    完美解決python中ndarray 默認用科學(xué)計數(shù)法顯示的問題

    今天小編就為大家分享一篇完美解決python中ndarray 默認用科學(xué)計數(shù)法顯示的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-07-07
  • Python+tkinter使用80行代碼實現(xiàn)一個計算器實例

    Python+tkinter使用80行代碼實現(xiàn)一個計算器實例

    這篇文章主要介紹了Python+tkinter使用80行代碼實現(xiàn)一個計算器實例,具有一定借鑒價值,需要的朋友可以參考下
    2018-01-01
  • Python使用BeautifulSoup4修改網(wǎng)頁內(nèi)容的實戰(zhàn)記錄

    Python使用BeautifulSoup4修改網(wǎng)頁內(nèi)容的實戰(zhàn)記錄

    BeautifulSoup除了可以查找和定位網(wǎng)頁內(nèi)容,還可以修改網(wǎng)頁,下面這篇文章主要給大家介紹了關(guān)于Python使用BeautifulSoup4修改網(wǎng)頁內(nèi)容的相關(guān)資料,需要的朋友可以參考下
    2022-05-05
  • python實現(xiàn)手勢識別的示例(入門)

    python實現(xiàn)手勢識別的示例(入門)

    這篇文章主要介紹了python實現(xiàn)手勢識別的示例(入門),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • Python的生成器函數(shù)詳解

    Python的生成器函數(shù)詳解

    這篇文章主要介紹了Python的生成器函數(shù),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-02-02

最新評論