1

我正在尝试在地图上绘制最近的海面温度数据。我在下载 netCDF4 文件时让它工作了,但是当我尝试从https://www.ncei.noaa.gov/thredds/访问该文件时,我收到一个 TypeError 说,“输入 z 必须是 2D,而不是 3D ”。我最初使用的下载文件来自:https ://psl.noaa.gov/这是我所拥有的:

from netCDF4 import Dataset as netcdf_dataset
from datetime import datetime, timedelta

import matplotlib.pyplot as plt
import cartopy.crs as ccrs
import cartopy.feature as cfeature
from mpl_toolkits.axes_grid1.inset_locator import inset_axes

from siphon.catalog import TDSCatalog
from xarray.backends import NetCDF4DataStore
import xarray as xr

# Catalog only has data from day before so must use timedelta(days=1)
today = datetime.utcnow()
date = datetime(today.year, today.month, today.day, 12) - timedelta(days=1)


base_url = 'https://www.ncei.noaa.gov/thredds/catalog/OisstBase/NetCDF/V2.1/AVHRR/'
cat = TDSCatalog(f'{base_url}{date:%Y%m}/catalog.xml')
ncss = cat.datasets[f'oisst-avhrr-v02r01.{date:%Y%m%d}_preliminary.nc'].subset()

query = ncss.query()
query.time(date)
query.lonlat_box(north=31, south=20, east=283, west=262)
query.accept('netcdf')
query.variables('sst')

data = ncss.get_data(query)
ds = xr.open_dataset(NetCDF4DataStore(data))

sst = ds.variables['sst'][0, :,:]
lats = ds.variables['lat'][:]
lons = ds.variables['lon'][:]

fig = plt.figure(figsize=(15,10))
ax = fig.add_subplot(111, projection=ccrs.PlateCarree())

# TypeError occurs here
sst_contour = ax.contourf(lons, lats, sst, levels=np.arange(0,34,2), cmap='turbo',
                          vmin=0, vmax=38, transform=ccrs.PlateCarree())
isotherm_contour = ax.contour(lons, lats, sst, levels=[27], colors='black', linestyle='--',
                              transform=ccrs.PlateCarree())

这就是我使用从https://psl.noaa.gov/下载的文件的工作版本的样子。任何关于我在这里做错的输入将不胜感激:在此处输入图像描述

4

1 回答 1

1

从数据集中提取数据时,我没有考虑 zlev。改变

sst = ds.variables['sst'][0,:,:]

以下修复了我的错误

sst = ds.variables['sst'][0,0,:,:]

在此处输入图像描述 在此处输入图像描述

于 2021-04-17T17:14:48.693 回答