当前位置: 首页 > news >正文

网站备案要到哪里logo在线制作设计

网站备案要到哪里,logo在线制作设计,大连建设网站制作,如何接单做网站本文介绍基于Python中的gdal模块,批量基于大量多波段遥感影像文件,计算其每1景图像各自的NDVI数值,并将多景结果依次保存为栅格文件的方法。 如下图所示,现在有大量.tif格式的遥感影像文件,其中均含有红光波段与近红外…

  本文介绍基于Python中的gdal模块,批量基于大量多波段遥感影像文件,计算其每1景图像各自的NDVI数值,并将多景结果依次保存为栅格文件的方法。

  如下图所示,现在有大量.tif格式的遥感影像文件,其中均含有红光波段近红外波段(此外也可以含有其他光谱波段,有没有都不影响);我们希望,批量计算其每1景遥感影像的NDVI

  在之前的文章中,我们多次介绍过在不同软件或平台中计算NDVI的方法,大家可以参考文章ArcGIS中ArcMap快速自动计算单一波段或多波段栅格遥感影像NDVI的方法(https://blog.csdn.net/zhebushibiaoshifu/article/details/127290179),或者文章Google Earth Engine谷歌地球引擎GEE栅格代数与NDVI波段计算手动求取(https://blog.csdn.net/zhebushibiaoshifu/article/details/119145230)。而在本文中,我们就介绍一下基于Python中的gdal模块,实现NDVI批量计算的方法。

  这里所需的代码如下。

# -*- coding: utf-8 -*-
"""
Created on Thu Apr 18 12:37:22 2024@author: fkxxgis
"""import os
from osgeo import gdaloriginal_folder = r"E:\04_Reconstruction\99_MODIS\new_data\GF_Small\Rec"
output_folder = r"E:\04_Reconstruction\99_MODIS\new_data\GF_Small\NDVI"for filename in os.listdir(original_folder):if filename.endswith('.tif'):dataset = gdal.Open(os.path.join(original_folder, filename), gdal.GA_ReadOnly)width = dataset.RasterXSizeheight = dataset.RasterYSizedriver = gdal.GetDriverByName('GTiff')output_dataset = driver.Create(os.path.join(output_folder, "NDVI_" + filename), width, height, 1, gdal.GDT_Float32)band_red = dataset.GetRasterBand(3)data_red = band_red.ReadAsArray()band_nir = dataset.GetRasterBand(4)data_nir = band_nir.ReadAsArray()data_ndvi = (data_nir - data_red) / (data_nir + data_red)output_band = output_dataset.GetRasterBand(1)output_band.WriteArray(data_ndvi)output_band.FlushCache()output_dataset.SetGeoTransform(dataset.GetGeoTransform())output_dataset.SetProjection(dataset.GetProjection())dataset = Noneoutput_dataset = Noneprint(filename, "finished!")

  代码整体也非常简单。首先,我们定义输入文件与输入结果文件的路径,前者就是待计算NDVI的遥感影像文件路径,后者则是NDVI结果的遥感影像文件路径。

  接下来,遍历original_folder文件夹中的文件。其中,os.listdir()用于获取文件夹中的文件列表,其后的endswith('.tif')用于筛选出以.tif扩展名结尾的文件。

  随后,对于每个以.tif结尾的文件,首先使用gdal.Open()打开文件——其中的os.path.join()用于构建完整的文件路径;接下来获取影像数据集的宽度和高度,并使用gdal.GetDriverByName()获取GTiff驱动程序,用于创建输出影像文件;同时,使用driver.Create()创建一个与原始影像具有相同大小的输出影像文件。

  紧接着,从数据集中获取红光近红外波段的数据。dataset.GetRasterBand()用以获取指定的栅格波段,而band.ReadAsArray()则将波段数据读取为数组。

  其次,即可计算NDVI。使用获取的红光近红外波段数据计算NDVI,并将NDVI数据保存在data_ndvi数组中。

  最后,将NDVI数据写入输出影像文件。output_dataset.GetRasterBand()获取输出影像文件的波段,band.WriteArray()将数据写入波段,band.FlushCache()刷新波段缓存。

  此外,记得通过output_dataset.SetGeoTransform()output_dataset.SetProjection()设置输出影像文件的地理变换和投影信息。

  同时,需要清理和关闭数据集,将数据集和输出数据集设置为None以释放资源。还可以打印文件名finished!,表示当前文件处理完成。

  执行上述代码,我们即可在结果文件夹中看到计算得到的NDVI数据;如下图所示。

  至此,大功告成。

欢迎关注:疯狂学习GIS

http://www.yayakq.cn/news/676573/

相关文章:

  • 商务网站的特点购物网站建设价位
  • 网站建站历史网站轮播图
  • 公司做铸造的招聘网站都有哪些品牌商城网站制作
  • 有哪些建筑设计网站WordPress stock
  • 韩国男女直接做的视频网站电销系统哪个好
  • app开发公司属于什么行业百家号优化上首页
  • 网站建设公司赚钱吗温州论坛招聘
  • 做网站用的是什么语言网站建设多少钱个人
  • 做阿里巴巴网站应怎样定位烟台北京网站建设公司哪家好
  • 南京建设项目环评公示期网站网站建设分金手指科捷13
  • 奔驰宝马游戏网站建设对网站建设公司说
  • vr超市门户网站建设wordpress建站位置
  • 一个网站开发的意义科技感的网站
  • 手机怎样建设网站营销型网站开发流程
  • 莱芜网站建设电话戏曲网站建设的可行性分析
  • 物流建设网站有没有做软件的网站
  • 郑州中扬科技网站建设公司怎么样教育机构网站建设公司
  • 公司网站内容更新该怎么做省内新闻最新消息
  • 免费贴图素材网站安卓手机app开发用什么软件
  • 网站推广公司就去柚米盘锦网站建设策划
  • 衡水做wap网站价格图片类网站如何做优化
  • 公司的网站建设哪家比较好淘宝运营主要做些什么
  • 成品网站1688入门网百度百家号登录入口
  • 镇江网络违法网站设计软件图标
  • 景安服务器管理助手如何备份网站用了采集站域名做网站
  • 购物网站模板免费中小企业局域网组网方案
  • 网站网址更新了怎么查企业做网站哪家便宜
  • 手机微网站平台登录入口江苏seo排名
  • 五屏网站建设动态北京网站建设公司完美湖南岚鸿首 选
  • 电子政务网站建设ppt企业网站的综合要求