我在地圖上使用此代碼繪製數據:消除白邊
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)
這導致這個形象:
正如你所看到的,有白色的差距網格單元之間。我怎樣才能擺脫它們?
你可以把數據文件放在任何地方嗎? – tacaswell
不幸的是,不,但它是有規律的間隔網格數據。 – HyperCube
無論它值多少錢,我都無法使用隨機生成的(或常量)數據來重現您的問題......您使用的是什麼版本的matplotlib?也許它是一個已修復的錯誤?另外,在這種情況下'pcolormesh'會更快。嘗試使用它而不是'pcolor'。我懷疑(?)它會解決你的問題,但無論如何,它應該會更快。 –