首页 > 编程语言 >Python读取栅格图像并对像元数据处理后导出到表格文件中

Python读取栅格图像并对像元数据处理后导出到表格文件中

时间:2024-12-28 18:41:56浏览次数:1  
标签:读取 Python 格式文件 栅格 遥感 file csv data 影像

  本文介绍基于Python语言中的gdal模块,读取一景.tif格式的栅格遥感影像文件,提取其中每一个像元的像素数值,对像素值加以计算(辐射定标)后,再以一列数据的形式将计算后的各像元像素数据保存在一个.csv格式文件中的方法。

  首先,我们明确一下本文的需求。现在有一个栅格遥感影像文件,其为.tiff格式的文件(但其实和.tif格式文件的操作方法是一样的),且像元的数值都是真实数值乘上10000之后的。这一遥感影像如下图所示,可以看到其各个波段的像元像素数据都是几百、几千的范围。

image

  我们现在希望,对于这一景遥感影像的第一个波段(如果大家需要对多个波段加以这一操作,那么就在本文的代码中加以循环,分别对多个波段依次加以同样的处理就好),提取出其中每一个像元的数值;随后对提取出来的数据加以辐射定标,即除以10000,并将结果保存在一个.csv格式文件中,且以一列的形式来保存。这里本文之所以需要用多行一列而非多行多列矩阵格式来存放数据,是因为后面需要将这些像素数据当作神经网络的预测样本,即一行表示一个样本,所以就需要保存为多行一列;如果大家需要保存为多行多列矩阵格式,那代码的思路还是一致的,就是在导出数据之前将其保存为二维矩阵格式的变量就好。

  知道了需求,我们就可以开始代码的撰写;具体代码如下。

# -*- coding: utf-8 -*-
"""
Created on Wed Nov 29 01:32:28 2023

@author: fkxxgis
"""

import csv
from osgeo import gdal

file_path = "E:/04_Reconstruction/05_Image_Test/GF1WFV4.16m.2021252035621.48STB.000000_SR.tiff"
dataset = gdal.Open(file_path, gdal.GA_ReadOnly)

band = dataset.GetRasterBand(1)
data = band.ReadAsArray()
dataset = None

data = data * 0.0001
data_one_column = data.flatten()

csv_file = "E:/04_Reconstruction/05_Image_Test/column_1.csv"
with open(csv_file, 'w', newline='') as file:
    writer = csv.writer(file)
    writer.writerow(["Value"])
    writer.writerows([[value] for value in data_one_column])

  其中,我们首先导入所需的库。在这里,csv库用于处理.csv格式文件,gdal库(从osgeo模块中导入)则用于读取和处理遥感影像文件;随后,定义遥感影像文件路径——file_path用来指定要读取的遥感影像文件的路径。

  接下来,我们打开遥感影像文件。dataset = gdal.Open(file_path, gdal.GA_ReadOnly)意味着我们以只读方式打开遥感影像文件,并将返回的Dataset对象赋值给变量dataset;随后,获取第一个波段的像元值,这可以通过band = dataset.GetRasterBand(1)来完成(需要注意,这里波段编号的索引是从1开始的);随后,data = band.ReadAsArray()意思是将波段的像元值读取为一个二维数组,并将结果赋值给变量data。随后,我们需要关闭遥感影像文件,通过将dataset变量设为None,释放对遥感影像文件的引用,从而关闭文件。

  其次,我们对像元值进行处理。首先,完成辐射定标,也就是通过data = data * 0.0001将像元值乘以0.0001;随后,将处理后的像元值按列展平——在这里,data_one_column = data.flatten()表示我们使用flatten()方法将二维数组展平为一维数组,并将结果赋值给变量data_one_column

  最后,将上述处理好的数据写入.csv格式文件。其中,csv_file指定要写入的.csv格式文件的路径;with open(csv_file, 'w', newline='') as file表示我们使用open()函数打开.csv格式文件,并创建一个csv.writer对象,同时指定文件的写入模式为覆盖写入'w'writer.writerow(["Value"])意味着我们写入.csv格式文件的第一行,即表头,这里是一个标题为Value的列;最后,writer.writerows([[value] for value in data_one_column])通过迭代data_one_column中的每个值,并将其作为单独的列表传递给writer.writerows()方法,从而将每个值写入.csv格式文件的一行中。

  运行上述代码,即可得到如下图所示的结果.csv格式文件。

  其中,第一行就是我们的列名;后面几行数据都是0,这是由于原本的遥感影像在左上角区域NoData值(大家看我们本文的第一张图就能看到)导致的。如果往下继续拖动这个.csv格式文件,就会看到处理后的非0数据了。

  至此,大功告成。

标签:读取,Python,格式文件,栅格,遥感,file,csv,data,影像
From: https://www.cnblogs.com/fkxxgis/p/18637792

相关文章

  • 基于python+Django+mysql校园二手书籍交易平台系统设计与实现
     博主介绍:黄菊华老师《Vue.js入门与商城开发实战》《微信小程序商城开发》图书作者,CSDN博客专家,在线教育专家,CSDN钻石讲师;专注大学生毕业设计教育、辅导。所有项目都配有从入门到精通的基础知识视频课程,学习后应对毕业设计答辩,提供核心代码讲解,答辩指导。项目配有对应开发......
  • 猫眼电影Top250:Python爬虫与数据可视化实战
    猫眼电影Top250:探索电影的魅力与深度在电影的世界里,每一部作品都是一个独特的故事,而猫眼电影Top250则是这些故事中的精华所在。猫眼电影App作为一个集在线购票、电影资讯、影迷互动等服务的一站式电影平台,不仅为用户提供了便捷的购票服务,更是一个发现好电影的绝佳去处。1......
  • Python的秘密基地--[章节8] Python 数据科学与机器学习
    第8章:Python数据科学与机器学习随着大数据和人工智能的飞速发展,Python已成为数据科学和机器学习领域的首选编程语言。本章将深入探讨Python在数据科学和机器学习中的核心工具和技术,包括数据处理、可视化以及机器学习模型的构建。8.1数据科学简介8.1.1什么是数据科......
  • c语言书籍排序 多数组协同排序 按价格排序【书名同步】 带有空格的字符串读取
    题目:编写程序,从键盘输入n(n<10)本书的名称和定价并存入结构数组中,按单价从小到大排序并输出排序后的书籍信息。输入输出示例:括号内为说明,无需输入输出输入样例:3(n=3)ProgramminginC21.5ProgramminginVB18.5ProgramminginDelphi20输出样例:Programmingin......
  • python 打印圣诞树
    1.打印一棵简单的圣诞树defprint_christmas_tree(height):foriinrange(height):#打印每一层的空格print(""*(height-i-1),end="")#打印每一层的星号print("*"*(2*i+1))#打印树干for_inrange(2)......
  • WxPython跨平台开发框架之列表数据的通用打印处理
    在WxPython跨平台开发框架中,我们大多数情况下,数据记录通过wx.Grid的数据表格进行展示,其中表格的数据记录的显示和相关处理,通过在基类窗体 BaseListFrame进行统一的处理,因此对于常规的数据记录打印,我们也可以在其中集成相关的打印处理,本篇随笔介绍如何利用WxPython内置的打印数据......
  • Python变量与数据类型
    目录一,变量二,数据类型1.五种基本数据类型2.进制转换3.进制转换函数4.数据类型转换函数 5.type() 一,变量变量就是数据的别名,使用变量等同于使用数据,需要先赋值在使用。变量命名规则:1.只能包含字母,数字,下划线,其中数字不能开头2.区分大小写,一般变量名都是全......
  • Python基础3
    1.内存相关==和is有什么区别==用于比较值是否相等is用于比较内存地址是否相等2.小数据池/小整数缓存机制/驻留机制为了优化速度和内存使用设计,在一定范围内对整数进行复用,通常是[-5,256]由数字、字母、下划线组成的字符串简单字符串本身或*1时,符合小数据池由......
  • Spring Boot开发编译后读取不到@spring.profiles.active@的问题
    在使用IDEA进行SpringBoot项目开发时,如果遇到编译后读取不到@spring.profiles.active@的问题,这通常是由于以下几个原因导致的:Maven资源过滤未开启:在pom.xml中,需要确保资源过滤(resourcefiltering)已经开启,这样Maven在构建时会替换@spring.profiles.active@为实际的profile值......
  • python语言ddts爬虫程序代码QZQ
    #https://search.dangdang.com/?key=%C5%C0%B3%E6&act=inputimportrequestsimportosfromlxmlimportetreeimportosimportcsvimportcertifios.environ[‘REQUESTS_CA_BUNDLE’]=certifi.where()url=‘https://search.dangdang.com/?key=%C5%C0%B3%E6&a......