无法在python中使用matplotlib和cartopy绘制轮廓线子图

问题描述 投票:-2回答:1

我正在分析从NetCDF文件中绘制的2个图形,并将其划分为子图,我可以单独绘制,但不能作为子图绘制。没有显示任何错误,但图形不正确。

import xarray as xr
import matplotlib.pyplot as plt
import cartopy.crs as ccrs
import numpy as np
import cartopy.mpl.ticker as cticker

#%% OLR Import
fname ='/home/SIMS/P1/*.nc'                                              
ds = xr.open_mfdataset(fname)

olr = ds.olr
mea = ds.mean('time')

# OLR daily data import
cname ='/home/SIMS/olrr/OLR.nc'
dc = xr.open_dataset(cname)
colr = dc.olr

# calculating JJAS climatology 
def is_jjas(month):
    return (month >= 6) & (month <= 9)

seasonal_data_olr = colr.sel(time=is_jjas(colr['time.month']))
climatology = seasonal_data_olr.mean('time')
# Anomaly
anomaly_olr=mea-climatology



fig = plt.figure()
ax = plt.axes(projection=ccrs.Mercator(central_longitude=80.0, min_latitude=-10.0, max_latitude=20.0, globe=None, latitude_true_scale=0.0))
plt.subplot(2,1,1)
climatology.plot.contourf(ax=ax,transform=ccrs.PlateCarree(),vmin=0, vmax=245)
plt.subplot(2,1,2)
anomaly_olr.olr.plot.contourf(ax=ax, transform=ccrs.PlateCarree(),cmap="jet", vmin=-30, vmax=30)
plt.show()

我的变量

气候

xarray.DataArray'olr'(lat:15,lon:73)] >>

anomaly_olr.olr

xarray.DataArray'olr'(lat:15,lon:73)] >>

它给出了没有轮廓的图f

it gives this figure without contourf

我正在分析从NetCDF文件中绘制的2个图形,并将其划分为子图,我可以单独绘制,但不能作为子图绘制。没有显示任何错误,但图形不正确。导入...

python matplotlib subplot cartopy
1个回答
0
投票

进行少量更改后,我可以很好地进行绘制。我更改了以下几行,

plt.figure(figsize=(8, 10))
ax1 = plt.subplot(2,1,1, projection=ccrs.Mercator(central_longitude=80.0, min_latitude=-10.0, max_latitude=20.0, globe=None, latitude_true_scale=0.0))
anomaly_olr.olr.plot.contourf(ax=ax1, transform=ccrs.PlateCarree(),cmap="jet", vmin=-30, vmax=30)

ax2 = plt.subplot(2,1,2, projection=ccrs.Mercator(central_longitude=80.0, min_latitude=-10.0, max_latitude=20.0, globe=None, latitude_true_scale=0.0))
climatology.plot.contourf(ax=ax2,transform=ccrs.PlateCarree(),vmin=0, vmax=245)
plt.show()
© www.soinside.com 2019 - 2024. All rights reserved.