Google Earth Engine谷歌地球引擎GEE中ee.ImageCollection格式多张栅格图像数据基本处理操作

本文主要是介绍Google Earth Engine谷歌地球引擎GEE中ee.ImageCollection格式多张栅格图像数据基本处理操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

  本文主要对GEE中的ee.ImageCollection格式数据图层基本处理操作加以介绍。本文是谷歌地球引擎(Google Earth Engine,GEE)系列教学文章的第十一篇,更多GEE文章请参考专栏:GEE学习与应用(https://blog.csdn.net/zhebushibiaoshifu/category_11081040.html)。

  在第二篇GEE教学博客(https://blog.csdn.net/zhebushibiaoshifu/article/details/117296956)中,我们通过搜索的方式导入了GEE内置的遥感影像数据与各类矢量数据;而在第九篇GEE教学博客(https://blog.csdn.net/zhebushibiaoshifu/article/details/119545059)中,我们通过代码的方式获取了Landsat 5 Collection 1 Tier 1的大气表观反射率TOA Reflectance产品。本文依然采用代码方式,获取Landsat 8 Collection 1 Tier 1的初始影像Raw Scenes产品。

  其中,依据第十篇GEE教学博客(https://blog.csdn.net/zhebushibiaoshifu/article/details/119568274)中提及的ee.Geometry.Point()函数,设置一个点要素,作为后期研究区域的参照点(即获取能覆盖这一点要素的Landsat 8遥感影像);同时依据第二篇GEE教学博客(https://blog.csdn.net/zhebushibiaoshifu/article/details/117296956)中提及的遥感影像时间筛选方法,对Landsat 8遥感影像的时间段进行筛选。这里用到了两个之前教学博客中没有介绍的新函数——首先是.filterBounds()函数,作用为获取覆盖点要素point的遥感影像,即对遥感影像进行空间角度的筛选;其次是.sort()函数,作用为对ee.ImageCollection格式数据中的多层遥感影像按照一定规则进行排序。

var point=ee.Geometry.Point(116.36863, 39.961029);
var date_start=ee.Date("2020-05-01");
var date_end=ee.Date("2020-07-01");
var my_landsat=ee.ImageCollection("LANDSAT/LC08/C01/T1").filterBounds(point)
.filterDate(date_start,date_end).sort("CLOUD_COVER",true);
print(my_landsat);

  在这里,"CLOUD_COVER"表示遥感影像的云覆盖量,true表示按照排序指标的升序进行排列——即对于ee.ImageCollection格式数据中多景遥感影像,基于云覆盖量由少至多的顺序进行排列。还有需要强调的一点是,"CLOUD_COVER"并不是遥感影像波段的名称,而属于影像的元数据,或者说是属性。

在这里插入图片描述

  通过print()函数打印在右侧的信息,我们可以看到这个ee.ImageCollection格式数据中包含三个元素(即3 elements),也就是含有三景重叠的遥感影像。

在这里插入图片描述

  我们可以通过.first()函数获取一个ee.ImageCollection格式数据中的第一景影像。在这里,由于前述代码实现了云覆盖量由少至多的顺序进行排列,因此第一景影像也就是云覆盖量最低的那一景影像。

var first_landsat=my_landsat.first();
print(first_landsat);

在这里插入图片描述

  除了本文开头提及的按照一个点要素来筛选遥感影像,我们还可以按照LandsatPathRow分幅进行筛选。

//var point=ee.Geometry.Point(116.36863, 39.961029);
var date_start=ee.Date("2019-07-01");
var date_end=ee.Date("2020-06-01");
var my_landsat=ee.ImageCollection("LANDSAT/LC08/C01/T1")
.filter(ee.Filter.eq("WRS_PATH",123))
.filter(ee.Filter.eq("WRS_ROW",032))
.filterDate(date_start,date_end);
print(my_landsat);

  其中,ee.Filter.eq()函数表示按照某种方式进行筛选,"WRS_PATH"参数表示按照遥感影像属性中的Path分幅作为筛选标准,123表示筛选出Path号为123的遥感影像。

在这里插入图片描述

  筛选完后,我们可以将ee.ImageCollection格式数据中每一个要素的名称(即每一景遥感影像的名称)转为列表格式。

var list=my_landsat.toList(100);
print(list);

  其中,.toList()函数作用是将原有数据(ee.ImageCollection格式数据中每一个要素的名称)转为列表,100表示从ee.ImageCollection格式数据中获取要素名称的最大个数(即最多从ee.ImageCollection格式数据中获取100个要素的名称存入列表),这一参数只要远大于ee.ImageCollection格式数据中的要素个数即可。

在这里插入图片描述

  可以通过.length()函数获取列表数据的长度;这一长度也就是ee.ImageCollection格式数据中要素的个数。

var list_size=list.length();
print("The size of list is:",list_size);

在这里插入图片描述

  此外,还可以对ee.ImageCollection格式数据执行.size()函数,同样可以获取其要素个数。

var image_count=my_landsat.size();
print("The size of image is:",image_count);

在这里插入图片描述

  我们还可以对ee.ImageCollection格式数据的元数据(属性)进行获取。

print(my_landsat);

  首先,打印一下ee.ImageCollection格式数据,可以看到其properties中包含了很多属性信息;接下来我们就以date_range为例进行操作。date_range表示ee.ImageCollection格式数据中,遥感影像成像的起止时间。

在这里插入图片描述

  利用.get()函数就可以获取ee.ImageCollection格式数据的具体某一项属性。

var date_range=my_landsat.get("date_range");
print(date_range);

  打印出的起止时间格式如下图所示。这种用一长串数字来表示时间的格式为Unix Epoch,即Unix时间戳,其表示从1970年01月01 日00:00:00(GMT)开始以来的秒数;这里还需要注意,在JavaScript中,Unix Epoch的单位是毫秒,若要换为秒需要进行换算。

在这里插入图片描述

  我们还可以将起止时间转换为列表的形式。

var date_range_list=ee.List(date_range);
print(date_range_list);

  执行代码,可以看到是否转换为列表对于起止时间的显示而言并没有很大区别。

在这里插入图片描述

  Unix Epoch这种时间表示方法看起来不方便,我们可以将其转换为我们熟知的日期表示格式。

var date_range_ymd=ee.DateRange(date_range_list.get(0),date_range_list.get(1));
print("Date range is:",date_range_ymd);

  其中,ee.DateRange()就是一个可以起到转换时间格式作用的函数;同时,分别用.get()函数获取起止时间的第一个和第二个元素;第九篇GEE教学博客(https://blog.csdn.net/zhebushibiaoshifu/article/details/119545059)已经介绍过,列表元素初始下标为0,因此分别用01来获取列表中的第一个和第二个元素。

  起止时间转换后,我们可以看到2013年04月到2021年08月这个范围并不是前面我们用.filterDate(date_start,date_end)语句筛选后的日期,而是Landsat 8卫星发射并投入使用后到目前的时间;因此我们可以知道,ee.ImageCollection格式数据中properties内的date_range属性指的是整个初始数据集Landsat 8 Collection 1 Tier 1的初始影像Raw Scenes产品)的起止时间,而不是经过筛选后(包括经过成像时间筛选与空间筛选后)得到的剩下几景遥感影像的起止时间。

在这里插入图片描述

  还可以利用.aggregate_stats()函数统计ee.ImageCollection格式数据某一项属性的信息,其统计得到的信息包括ee.ImageCollection格式数据中,全部遥感影像的某一项属性值的极值、总和、平均值、标准差等。

var statistics=my_landsat.aggregate_stats("SUN_ELEVATION");
print(statistics);

在这里插入图片描述

  此外,可以将.sort()函数与.first()函数一起执行,从而获取排序后,排在第一位的那一景遥感影像。

var least_cloud=my_landsat.sort("CLOUD_COVER",true).first();
print(least_cloud);

  这里需要注意,执行上述代码后得到的是一景遥感影像(即ee.Image格式的数据)。

在这里插入图片描述

  同时,.sort()函数排序后,我们还可以获取排序前几位的遥感影像。

var recent_image=my_landsat.sort("system:time_start",false).limit(10);
print(recent_image);

  其中,利用.limit()函数获取有限的遥感影像,10表示获取10景,即获取成像时间离目前最近的10景遥感影像。因此,执行这一代码后获取的是多景遥感影像,即ee.ImageCollection格式的数据。

在这里插入图片描述

欢迎关注公众号/CSDN/知乎/微博:疯狂学习GIS

这篇关于Google Earth Engine谷歌地球引擎GEE中ee.ImageCollection格式多张栅格图像数据基本处理操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/393504

相关文章

Python将大量遥感数据的值缩放指定倍数的方法(推荐)

《Python将大量遥感数据的值缩放指定倍数的方法(推荐)》本文介绍基于Python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处理,并将所得处理后数据保存为新的遥感影像... 本文介绍基于python中的gdal模块,批量读取大量多波段遥感影像文件,分别对各波段数据加以数值处

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存

Golang操作DuckDB实战案例分享

《Golang操作DuckDB实战案例分享》DuckDB是一个嵌入式SQL数据库引擎,它与众所周知的SQLite非常相似,但它是为olap风格的工作负载设计的,DuckDB支持各种数据类型和SQL特性... 目录DuckDB的主要优点环境准备初始化表和数据查询单行或多行错误处理和事务完整代码最后总结Duck

Python MySQL如何通过Binlog获取变更记录恢复数据

《PythonMySQL如何通过Binlog获取变更记录恢复数据》本文介绍了如何使用Python和pymysqlreplication库通过MySQL的二进制日志(Binlog)获取数据库的变更记录... 目录python mysql通过Binlog获取变更记录恢复数据1.安装pymysqlreplicat

Linux使用dd命令来复制和转换数据的操作方法

《Linux使用dd命令来复制和转换数据的操作方法》Linux中的dd命令是一个功能强大的数据复制和转换实用程序,它以较低级别运行,通常用于创建可启动的USB驱动器、克隆磁盘和生成随机数据等任务,本文... 目录简介功能和能力语法常用选项示例用法基础用法创建可启动www.chinasem.cn的 USB 驱动

IDEA如何将String类型转json格式

《IDEA如何将String类型转json格式》在Java中,字符串字面量中的转义字符会被自动转换,但通过网络获取的字符串可能不会自动转换,为了解决IDEA无法识别JSON字符串的问题,可以在本地对字... 目录问题描述问题原因解决方案总结问题描述最近做项目需要使用Ai生成json,可生成String类型

C# 读写ini文件操作实现

《C#读写ini文件操作实现》本文主要介绍了C#读写ini文件操作实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录一、INI文件结构二、读取INI文件中的数据在C#应用程序中,常将INI文件作为配置文件,用于存储应用程序的

使用Python进行文件读写操作的基本方法

《使用Python进行文件读写操作的基本方法》今天的内容来介绍Python中进行文件读写操作的方法,这在学习Python时是必不可少的技术点,希望可以帮助到正在学习python的小伙伴,以下是Pyth... 目录一、文件读取:二、文件写入:三、文件追加:四、文件读写的二进制模式:五、使用 json 模块读写

Python使用qrcode库实现生成二维码的操作指南

《Python使用qrcode库实现生成二维码的操作指南》二维码是一种广泛使用的二维条码,因其高效的数据存储能力和易于扫描的特点,广泛应用于支付、身份验证、营销推广等领域,Pythonqrcode库是... 目录一、安装 python qrcode 库二、基本使用方法1. 生成简单二维码2. 生成带 Log