当前位置: 首页 > news >正文

NC文件不规则裁剪(利用shp文件裁剪)(三)

文章目录

  • 前言
  • 实例数据
  • 代码部分
    • 需要的库
    • 加载文件
    • 写入地理信息
    • 裁剪NC
    • 结果
  • 完整代码奉上

前言

Hello大家好呀,最近正好需要用到多个SHP去裁剪NC,按照我以前的两种办法(办法1和办法2)操作的话,我自己都会破防,在偶然的情况下发现了rioxarray这个库。这个库可以将坐标信息直接写入到NC之中,从而直接使用shp裁剪,比原先的方法更为简单明了。

实例数据

本次测试数据采用2m气温数据,下载链接:点我直接下载;
NC数据打开后如下图所示,该数据为逐月的三维数据。
在这里插入图片描述

SHP数据我就直接采用NOAA公开的海岸线数据吧,主要是涉及到中国的SHP极大可能性会被平台封文章。下载链接:点我直接下载。数据如下图所示,我用的文件是GSHHS_i_L1.shp

在这里插入图片描述

代码部分

需要的库

本次我们需要用到以下四个库,这几个库都可以直接用pip安装比较方便。

import xarray as xr
import rioxarray
import geopandas as gpd
from shapely.geometry import mapping

加载文件

ds = xr.open_dataset(r'C:\Users\Administrator\Downloads/air.2m.mon.mean.nc') # 加载NC文件
# ds['lon'] = ds['lon'] -180
shp = gpd.read_file(r"D:\BaiduNetdiskDownload\gshhg-shp-2.3.7\GSHHS_shp\i/GSHHS_i_L1.shp") # 加载shp文件

写入地理信息

ds.rio.write_crs("epsg:4326", inplace=True) # 向NC文件中写入WGS84坐标系信息
ds.rio.set_spatial_dims(x_dim="lon", y_dim="lat", inplace=True) # 指定NC文件的xy识别名称

裁剪NC

ds = ds.rio.clip(shp.geometry.apply(mapping),shp.crs,drop=False)

结果

在这里插入图片描述

结果是出来了,但是我们会发现,数据只有0-180度之间的,而-180-0之间的数据没有了,造成这个问题的原因就是NCEP数据的lon是从0-360的,而这个库识别不出来。因此在裁剪之前我们需要仔细的观察一下数据的lon是否是从-180开始的。如果是从-180开始的就不用管了,如果是从0开始的就需要将加载文件那一步中的ds[‘lon’] = ds[‘lon’] -180取消注释。

经过lon处理后的结果就是正常的啦!!
在这里插入图片描述

完整代码奉上

import xarray as xr
import rioxarray
import geopandas as gpd
from shapely.geometry import mappingds = xr.open_dataset(r'C:\Users\Administrator\Downloads/air.2m.mon.mean.nc')
# ds['lon'] = ds['lon'] - 180 # 根据实际NC文件的经度范围确定是否开启这一行
shp = gpd.read_file(r"D:\BaiduNetdiskDownload\gshhg-shp-2.3.7\GSHHS_shp\i/GSHHS_i_L1.shp")ds.rio.write_crs("epsg:4326", inplace=True)
ds.rio.set_spatial_dims(x_dim="lon", y_dim="lat", inplace=True)ds = ds.rio.clip(shp.geometry.apply(mapping),shp.crs,drop=False)ds.to_netcdf(r'D:\CSDN/air.2m.mon.mean_clip.nc') # 保存NC文件
http://www.lryc.cn/news/302728.html

相关文章:

  • java 宠物在线商城系统Myeclipse开发mysql数据库web结构jsp编程servlet计算机网页项目
  • 三防平板丨手持工业平板丨ONERugged工业三防平板丨推动数字化转型
  • 【Linux | C++ 】基于环形队列的多生产者多消费者模型(Linux系统下C++ 代码模拟实现)
  • 【Docker】Docker存储卷
  • 基于python的租车管理平台/汽车租赁网站
  • 【JVM】双亲委派机制
  • 分布式id实战
  • 深入了解 SOCKS5 代理、代理 IP 和 HTTP
  • 外包干了3个多月,技术退步明显。。。。
  • Unity之闪电侠大战蓝毒兽(简陋的战斗系统)
  • C# 菜鸟级别有关于redis的使用
  • AlexNet的出现推动深度学习的巨大发展
  • 2024面试offer收割宝典字节篇
  • 冒泡排序及其优化
  • 【医学大模型 补全主诉】BioGPT + LSTM 自动补全医院紧急部门主诉
  • HCIE-Datacom证书有效期多久?HCIE考试有哪些内容?
  • OpenCV中的边缘检测技术及实现
  • 机器学习基础(一)理解机器学习的本质
  • Eclipse - Makefile generation
  • Sora:新一代实时音视频通信框架
  • 龟兔赛跑算法
  • Yii2项目使用composer异常记录
  • 【蓝桥杯 2021】图像模糊
  • 【leetcode】贪心算法介绍
  • com.alibaba.fastjson.JSONException: toJSON error的原因
  • 华为配置旁挂二层组网直接转发示例
  • OLMo 以促进语言模型科学之名 —— OLMo Accelerating the Science of Language Models —— 全文翻译
  • 单例模式双端检测详解
  • 秦PLUS荣耀版7.98万元起震撼上市,拉开“电比油低”大幕
  • 学习总结19