w_mmmy 2022-11-08 11:07 采纳率: 0%
浏览 16

关于#Python#计算NDVI的问题

用Python计算Landsat8 OLI影像文件的NDVI值,所得结果为负数

代码如下

# 导入包
from osgeo import gdal
import numpy as np
from osgeo import gdal_array
import os

# 读取
FilePath = 'D:\\Co\\4\\output'
tif_name = os.listdir(FilePath)  # 读取FilePath下的目录名,包含扩展名
SavePath = 'D:\\Co\\4\\output\\outputNDVI'
print(tif_name)

ReadName = 'D:\\Co\\4\\output\\dqjz_daiyue'
SaveName = 'D:\\Co\\4\\output\\outputNDVI\\d9.tif'
dataset = gdal.Open(ReadName)
cols = dataset.RasterXSize  # 列数
rows = dataset.RasterYSize  # 行数  空间坐标 可以理解为行列号

# 计算 NDVI=(NIR-RED)/(NIR+RED)
# 提取红波段
band_red = dataset.GetRasterBand(3)
data_red = band_red.ReadAsArray(0, 0, cols, rows).astype(np.float64)   # 根据位置获取像素值
# 提取近红外波段
band_nir = dataset.GetRasterBand(4)
data_nir = band_nir.ReadAsArray(0, 0, cols, rows).astype(np.float64)
ndvi = ((data_nir - data_red) * 0.1) / (((data_nir + data_red)+ 1E-6) * 0.1)
# 警示错误的运算
gdal_array.numpy.seterr(all="warn")

# 创建栅格数据集
driver = gdal.GetDriverByName('GTiff')  # 将GTiff图纸实体化为driver,括号内为文件类型
dataset_out = driver.Create(SaveName, cols, rows, 1, gdal.GDT_Float64)  # 这里的1指的是创建的栅格数据文件只能容纳一个波段
# 定义仿射矩阵和投影信息
dataset_out.SetGeoTransform(dataset.GetGeoTransform())
dataset_out.SetProjection(dataset.GetProjection())
# 写入像素值
band_out = dataset_out.GetRasterBand(1)
band_out.WriteArray(ndvi)  # 把数组写入到栅格数据相应的波段中
# 清空缓存,关闭数据集
dataset.FlushCache()
dataset_out.FlushCache()  # 把内存中的数据写入到文件中
del dataset
del dataset_out

运行结果及报错内容

在ENVI中打开后作对比,如下

img

请问是哪里出现了问题?百思不得其解。

  • 写回答

1条回答 默认 最新

  • CSDN-Ada助手 CSDN-AI 官方账号 2022-11-08 14:30
    关注
    评论

报告相同问题?

问题事件

  • 创建了问题 11月8日

悬赏问题

  • ¥15 征集Python提取PDF文字属性的代码
  • ¥15 有偿求苍穹外卖环境配置
  • ¥15 代码在keil5里变成了这样怎么办啊,文件图像也变了,
  • ¥20 Ue4.26打包win64bit报错,如何解决?(语言-c++)
  • ¥15 clousx6整点报时指令怎么写
  • ¥30 远程帮我安装软件及库文件
  • ¥15 关于#自动化#的问题:如何通过电脑控制多相机同步拍照或摄影(相机或者摄影模组数量大于60),并将所有采集的照片或视频以一定编码规则存放至规定电脑文件夹内
  • ¥20 深信服vpn-2050这台设备如何配置才能成功联网?
  • ¥15 Arduino的wifi连接,如何关闭低功耗模式?
  • ¥15 Android studio 无法定位adb是什么问题?