使用python批量计算栅格像元值(像元总值等)

1. 单个栅格像元数值计算

python 复制代码
import rasterio
from rasterio import plot
import numpy as np
from scipy.stats import mode

# 打开TIF文件
with rasterio.open('path.tiff') as src:
    # 读取栅格数据
    data = src.read(1)  # 只读取第一个band

    # 计算总像元值
    total_pixel_value = np.sum(data)

    # 计算最大值
    max_value = np.max(data)

    # 计算最小值
    min_value = np.min(data)

    # 计算平均值
    mean_value = np.mean(data)

    # 计算中位数
    median_value = np.median(data)

    # 计算众数
    mode_value, _ = mode(data, axis=None)

    # 计算均方根误差(RMSE)
    # 假设你有一个参考值或者你想使用所有像元的平方和的平均值来计算RMSE
    # 这里我们使用整个数据集的平方和的平均值来近似计算RMSE
    rmse = np.sqrt(np.mean(data**2))

    # 打印结果
    print(f"总像元值: {total_pixel_value}")
    print(f"最大值: {max_value}")
    print(f"最小值: {min_value}")
    print(f"平均值: {mean_value}")
    print(f"中位数: {median_value}")
    print(f"众数: {mode_value}")
    print(f"均方根误差 (RMSE): {rmse}")

2. 批量计算并写入csv

python 复制代码
import rasterio
from rasterio import plot
import numpy as np
from scipy.stats import mode
import os
import csv

# 指定要处理的TIF文件所在的目录
tif_directory = 'path_to_your_tif_directory'

# 指定输出CSV文件的路径
output_csv_file = 'output.csv'

# 定义要写入CSV文件的列名
column_names = ['Filename', 'Total Pixel Value', 'Max Value', 'Min Value', 'Mean Value', 'Median Value', 'Mode Value', 'RMSE']

# 打开CSV文件进行写入
with open(output_csv_file, mode='w', newline='', encoding='utf-8') as csv_file:
    writer = csv.writer(csv_file)

    # 写入列名
    writer.writerow(column_names)

    # 遍历TIF文件列表
    for tif_file in os.listdir(tif_directory):
        if tif_file.endswith('.tiff'):
            # 构建完整的文件路径
            file_path = os.path.join(tif_directory, tif_file)

            # 打开TIF文件
            with rasterio.open(file_path) as src:
                # 读取栅格数据
                data = src.read(1)  # 只读取第一个band

                # 计算总像元值
                total_pixel_value = np.sum(data)

                # 计算最大值
                max_value = np.max(data)

                # 计算最小值
                min_value = np.min(data)

                # 计算平均值
                mean_value = np.mean(data)

                # 计算中位数
                median_value = np.median(data)

                # 计算众数
                mode_value, _ = mode(data, axis=None)

                # 计算均方根误差(RMSE) 
                # 这里我们使用整个数据集的平方和的平均值来近似计算RMSE
                rmse = np.sqrt(np.mean(data**2))

                # 写入CSV文件
                writer.writerow([tif_file, total_pixel_value, max_value, min_value, mean_value, median_value, mode_value, rmse])

print(f"统计数据已写入 {output_csv_file}")

说明:在计算tif栅格像元值的时候需要注意tif的数值类型,整数还是浮点。

在计算6位数值时,python会自动转成8位byte,这会影响计算结果。


感谢阅读

相关推荐
Python+JAVA+大数据8 小时前
TCP_IP协议栈深度解析
java·网络·python·网络协议·tcp/ip·计算机网络·三次握手
一个无名的炼丹师9 小时前
多模态RAG系统进阶:从零掌握olmOCR与MinerU的部署与应用
python·大模型·ocr·多模态·rag
u0109272719 小时前
使用XGBoost赢得Kaggle比赛
jvm·数据库·python
MediaTea9 小时前
<span class=“js_title_inner“>Python:实例对象</span>
开发语言·前端·javascript·python·ecmascript
feasibility.9 小时前
多模态模型Qwen3-VL在Llama-Factory中断LoRA微调训练+测试+导出+部署全流程--以具身智能数据集open-eqa为例
人工智能·python·大模型·nlp·llama·多模态·具身智能
我需要一个支点9 小时前
douyin无水印视频下载
爬虫·python
喵手9 小时前
Python爬虫实战:采集各大会展平台的展会名称、举办时间、展馆地点、主办方、行业分类等结构化数据(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集大会展平台信息·展会名称举办时间展馆地址·采集数据csv/json导出
编码者卢布10 小时前
【Azure APIM】如何实现对经过APIM并到达后端服务请求的全链路追踪呢?
python·flask·azure
0思必得010 小时前
[Web自动化] Selenium执行JavaScript语句
前端·javascript·爬虫·python·selenium·自动化
焱童鞋10 小时前
解决 MeteoInfoLab 3.9.11 中 contourfm 导致的 ArrayIndexOutOfBoundsException
开发语言·python