NC文件根据经纬度提取点上数值

Hello,Hello,Hello,大家好,时隔上一次更新已经很久了,今天主要和大家分享一组简单的代码,来提取NC文件中某一点的数值!

实例数据说明

本次实例数据依旧使用喜闻乐见的NCEP数据,数据使用的是多层气温。或者可以直接点击这里下载
在这里插入图片描述
这个就是下载好的数据:
在这里插入图片描述
大家可以看一下,这个数据是四维数据(Level维、Time维、经度、纬度),大家一般在使用的过程中也就是提取某一个Level的某一格点的全时间序列数据(下面会详细讲解的)。

代码部分

首先,我们加载一下刚刚下载好的数据。

import xarray as xr
import numpy as np
import pandas as pd
ds = xr.open_dataset(r'air.mon.mean.nc')
ds

在这里插入图片描述
大家需要注意的是,这个数据是四维的,所以在我们之后提取的过程中就需要注意这一点。
然后我选取了1000hPa这一层的气温

ds = ds.sel(level=1000)
ds

在这里插入图片描述
紧接着,就是正题,根据经纬度读取数据

find_latindex = 32.5 #需要查询的纬度
find_lonindex = 120.5 #需要查询的经度

air_tem = ds['air'].values #读取气温数据
lon = ds['lon'].values.tolist() #读取经度,并且一定要转化为列表格式,因为后面所使用的函数不支持numpy或者其他格式
lat = ds['lat'].values.tolist() #读取纬度

#查询距离指定纬度最近的格点
lat_index = lat.index(min(lat, key=lambda x: abs(x - find_latindex))) 
lon_index = lon.index(min(lon, key=lambda x: abs(x - find_lonindex)))

#读取数据
air_select = air_tem[:, lat_index, lon_index]
time = ds['time'].values

在这里插入图片描述
最后转化为DateForm并输出成Excel

df = pd.DataFrame({'time': time, 'air': air_select})
df.to_excel('air.xlsx', index=False)

在这里插入图片描述

完整代码

import xarray as xr
import numpy as np
import pandas as pd
ds = xr.open_dataset(r'air.mon.mean.nc')
ds = ds.sel(level=1000)
find_latindex = 32.5
find_lonindex = 120.5

air_tem = ds['air'].values
lon = ds['lon'].values.tolist()
lat = ds['lat'].values.tolist()

lat_index = lat.index(min(lat, key=lambda x: abs(x - find_latindex)))
lon_index = lon.index(min(lon, key=lambda x: abs(x - find_lonindex)))
#读取数据
air_select = air_tem[:, lat_index, lon_index]
time = ds['time'].values
df = pd.DataFrame({'time': time, 'air': air_select})
df.to_excel('air.xlsx', index=False)

最后的效果如下图所示:
在这里插入图片描述

拜拜啦

评论 28
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

卷心没有菜

你若晌饭便是义父!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值