16

我正在使用以下代码在地图上绘制数据:

import numpy as np
import matplotlib as mpl
import matplotlib.pyplot as plt
import matplotlib.cm as cm
from mpl_toolkits.basemap import Basemap
from matplotlib.patches import Polygon
from scipy.io import netcdf

ncfile = netcdf.netcdf_file(myfile.nc,'r')
lon = ncfile.variables['longitude'][:]
lat = ncfile.variables['latitude'][:]
data = ncfile.variables['mydata'][:]
ncfile.close()

m = Basemap(projection='nplaea', boundinglat=40, lon_0=270)
m.drawcoastlines(linewidth=.6, zorder=2)
m.drawparallels(np.arange(-80.,81.,20.), zorder=1)
m.drawmeridians(np.arange(-180.,181.,20.), zorder=1)
cNorm = mpl.colors.Normalize(vmin=0, vmax=np.nanmax(data))
cmap = plt.get_cmap('jet')
lons, lats = np.meshgrid(lon, lat)
x, y = m(lons, lats)
datamap = m.pcolor(x, y, data, zorder=0)
datamap.set_norm(cNorm) 
plt.colorbar(datamap, cmap=cmap, norm=cNorm, shrink=0.5)
plt.savefig('figures/map_polar.png', dpi=150, bbox_inches='tight', pad_inches=0.4)

这导致了这个图像:在此处输入图像描述

如您所见,网格单元之间存在白色间隙。我怎样才能摆脱它们?

4

3 回答 3

3

我知道这是一个老问题,但我想我会为这个问题添加我的解决方案。当我遇到与您完全相同的问题时,我发现了您的问题,即我的绘图中有一条白线和一个从-180 到 180 的网格。我的解决方案是使用 Basemap 函数addcyclic

from mpl_toolkits.basemap import Basemap, shiftgrid, addcyclic
SSTcyclic, lonCMIP5cyclic = addcyclic(SST, lonCMIP5)

这解决了我的问题。干杯,特隆德

于 2013-08-19T18:16:09.470 回答
2

在我看来,原来的帖子实际上并没有询问0360度之间的白色区域。

我认为 OP 正在谈论与此错误一致的每个颜色方块之间的线条:

似乎将 pcolor 绘图保存为 pdf 格式总是包含网格线,这对于其他输出格式(如 png)而言并非如此

以下是开发人员对这个问题的看法:

我在 gs、xpdf Preview.app 中看到生成的图像中的网格线,但在 Adob​​e Reader 中没有。当我放大预览时,线条会跳动一点,并且无论缩放级别如何,屏幕上的宽度始终相同。

在这个例子中绘制的是很多多边形,因此相邻的多边形共享一条具有完全相同坐标的边。代码填充了每个多边形的内部,显然一些渲染算法在多边形之间留下了一条最小宽度的线。

所以这是 PDF 查看器的问题,而pcolor不是matplotlib.

于 2014-11-12T19:35:07.027 回答
2

我曾经遇到过同样的问题。问题很可能出在longitude. 确保0360都存在于输入中。如果没有,请手动添加它们,并相应地进行更改,mydata使它们具有相同的形状。

于 2012-12-02T00:02:21.570 回答