GEE提取水体

2024-01-24 14:38
文章标签 提取 gee 水体

本文主要是介绍GEE提取水体,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

GEE提取水体

老板需要提取2015-2019年,每年4、7、10月份的水体数据,一个月的卫片需要4张才能盖住研究区,我表示有点儿懵,看了大神的文章(https://blog.csdn.net/weixin_36396470/article/details/106899589),毅然入坑GEE!!!
然而,坑入的并不顺利,科学上网、用户申请、环境搭建(到现在还没搭好本地的Python环境)一步一个坎儿,下回整理一下发出来吧,今天主要说水体的提取问题。

1.工作环境

由于时间短、任务急,我直接参考大神的代码,在线上的JS环境进行编程处理了(JS啊,有点儿崩溃,没事儿的时候肯定搭一个Python的)。https://code.earthengine.google.com(线上JS环境)。

2.主要思路

主要利用GEE里的JRC Monthly Water History,v1.2库进行水体指数的提取,这里是根据Landsat提取的全球各月的水体,很棒。利用自己上传的矢量文件进行空间划定,最终得到想要的水体数据。

3.代码实现

  • 导入库和矢量文件
    在这里插入图片描述
    矢量文件的导入需要在左侧的NEW中选择shp,然后上传完整的shp文件。
    在这里插入图片描述
    在这里插入图片描述
    上传结束后import即可。
    在这里插入图片描述
  • 设置基础变量
    yantze_down_region为矢量文件,year为提取年份,startDate、endDate开始与结束日期,myjrc为jrc库的数据,viz为输出时栅格颜色。
var yantze_down_region = table.geometry();
var year = 2019
var startDate = ee.Date.fromYMD(year, 1, 1);
var endDate = ee.Date.fromYMD(year, 12, 31);
var myjrc = jrc.filterDate(startDate, endDate);
var viz = {min:0, max:2, palette: ['blue', 'white', 'green']};
  • 数据筛选
    原谅我第一次用JS,还不会循环啥的,只能是手写啦。这一部分主要是提取相应的水体文件。myjrc为ImageCollection对象,不知道为啥,针对它的空间筛选函数filterBounds死活筛选不出来,出来的结果总是全世界的,所以把myjrc转换为list,然后通过get选取相应月份的数据,利用Image函数转变为Image对象,最后利用select选择水体数据标签。(由于3各月,我建立了3个变量。)Image对象可以被clip进行裁剪。Map.addLayer函数可以显示处理后的文件。
myjrc = myjrc.toList(12);
var a = ee.Image(myjrc.get(3)).select("water")
var b = ee.Image(myjrc.get(6)).select("water")
var c = ee.Image(myjrc.get(9)).select("water")
Map.addLayer(a.clip(yantze_down_region),viz);
  • 面积统计
    对数据进行像元数统计,eq可以筛选标签为2的数据(水体数据),最后可以print出像元个数,可以在console中看到。
var stats2 = a.eq(2).reduceRegion({reducer: ee.Reducer.sum(),geometry: yantze_down_region,scale: 30,maxPixels: 1E13});
var stats3 = b.eq(2).reduceRegion({reducer: ee.Reducer.sum(),geometry: yantze_down_region,scale: 30,maxPixels: 1E13});
var stats4 = c.eq(2).reduceRegion({reducer: ee.Reducer.sum(),geometry: yantze_down_region,scale: 30,maxPixels: 1E13});

在这里插入图片描述

  • 图像导出
    toDrive函数可以进行图像的导出,导出后图像可以在tasks中看到,点击run下载即可。
Export.image.toDrive({image: a.clip(yantze_down_region),scale: 30,maxPixels : 1e13,folder:year+"04",description:year+"04"});
Export.image.toDrive({image: b.clip(yantze_down_region),scale: 30,maxPixels : 1e13,folder:year+"07",description:year+"07"});
Export.image.toDrive({image: c.clip(yantze_down_region),scale: 30,maxPixels : 1e13,folder:year+"10",description:year+"10"});

在这里插入图片描述

这篇关于GEE提取水体的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python从Word文档中提取图片并生成PPT的操作代码

《Python从Word文档中提取图片并生成PPT的操作代码》在日常办公场景中,我们经常需要从Word文档中提取图片,并将这些图片整理到PowerPoint幻灯片中,手动完成这一任务既耗时又容易出错,... 目录引言背景与需求解决方案概述代码解析代码核心逻辑说明总结引言在日常办公场景中,我们经常需要从 W

Java+AI驱动实现PDF文件数据提取与解析

《Java+AI驱动实现PDF文件数据提取与解析》本文将和大家分享一套基于AI的体检报告智能评估方案,详细介绍从PDF上传、内容提取到AI分析、数据存储的全流程自动化实现方法,感兴趣的可以了解下... 目录一、核心流程:从上传到评估的完整链路二、第一步:解析 PDF,提取体检报告内容1. 引入依赖2. 封装

Java使用正则提取字符串中的内容的详细步骤

《Java使用正则提取字符串中的内容的详细步骤》:本文主要介绍Java中使用正则表达式提取字符串内容的方法,通过Pattern和Matcher类实现,涵盖编译正则、查找匹配、分组捕获、数字与邮箱提... 目录1. 基础流程2. 关键方法说明3. 常见场景示例场景1:提取所有数字场景2:提取邮箱地址4. 高级

Python 字符串裁切与提取全面且实用的解决方案

《Python字符串裁切与提取全面且实用的解决方案》本文梳理了Python字符串处理方法,涵盖基础切片、split/partition分割、正则匹配及结构化数据解析(如BeautifulSoup、j... 目录python 字符串裁切与提取的完整指南 基础切片方法1. 使用切片操作符[start:end]2

使用Python提取PDF大纲(书签)的完整指南

《使用Python提取PDF大纲(书签)的完整指南》PDF大纲(Outline)​​是PDF文档中的导航结构,通常显示在阅读器的侧边栏中,方便用户快速跳转到文档的不同部分,大纲通常以层级结构组织,包含... 目录一、PDF大纲简介二、准备工作所需工具常见安装问题三、代码实现完整代码核心功能解析四、使用效果控

Linux从文件中提取特定内容的实用技巧分享

《Linux从文件中提取特定内容的实用技巧分享》在日常数据处理和配置文件管理中,我们经常需要从大型文件中提取特定内容,本文介绍的提取特定行技术正是这些高级操作的基础,以提取含有1的简单需求为例,我们可... 目录引言1、方法一:使用 grep 命令1.1 grep 命令基础1.2 命令详解1.3 高级用法2

Python实现批量提取BLF文件时间戳

《Python实现批量提取BLF文件时间戳》BLF(BinaryLoggingFormat)作为Vector公司推出的CAN总线数据记录格式,被广泛用于存储车辆通信数据,本文将使用Python轻松提取... 目录一、为什么需要批量处理 BLF 文件二、核心代码解析:从文件遍历到数据导出1. 环境准备与依赖库

Python中提取文件名扩展名的多种方法实现

《Python中提取文件名扩展名的多种方法实现》在Python编程中,经常会遇到需要从文件名中提取扩展名的场景,Python提供了多种方法来实现这一功能,不同方法适用于不同的场景和需求,包括os.pa... 目录技术背景实现步骤方法一:使用os.path.splitext方法二:使用pathlib模块方法三

Python实现精准提取 PDF中的文本,表格与图片

《Python实现精准提取PDF中的文本,表格与图片》在实际的系统开发中,处理PDF文件不仅限于读取整页文本,还有提取文档中的表格数据,图片或特定区域的内容,下面我们来看看如何使用Python实... 目录安装 python 库提取 PDF 文本内容:获取整页文本与指定区域内容获取页面上的所有文本内容获取

C/C++的OpenCV 进行图像梯度提取的几种实现

《C/C++的OpenCV进行图像梯度提取的几种实现》本文主要介绍了C/C++的OpenCV进行图像梯度提取的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录预www.chinasem.cn备知识1. 图像加载与预处理2. Sobel 算子计算 X 和 Y