Я прочитал этот вопрос: Overlay shape file on matplotlib, и я не уверен, что это относится ко мне, но у меня есть шейп-файл моей страны, и я хочу наложить данные о осадках из файла GRIB на этот файл формы. Это использование pygrib и matplotlib. Я не заинтересован в использовании Basemap.coastlines() и Basemap.countries(), потому что это доступно в шейп-файле. Я хочу переопределить это с помощью своего собственного шейп-файла. Как мне это сделать ?Как наложить данные о осадках на шейп-файл с использованием matplotlib и pygrib?
#!/usr/bin/python3.4
import numpy as np
import pygrib
import shapefile
import matplotlib.pyplot as plt
from mpl_toolkits.basemap import Basemap
grbs = pygrib.open('00020000')
grb = grbs.select(name='Total Precipitation')[0]
data = grb.values
lat,lon = grb.latlons()
m=Basemap(projection='mill',lat_ts=10,llcrnrlon=lon.min(), \
urcrnrlon=lon.max(),llcrnrlat=lat.min(),urcrnrlat=lat.max(), \
resolution='c')
m.readshapefile("adm3.shp")
x,y=m(lon,lat)
cs = m.pcolormesh(x,y,data,shading='flat',cmap=plt.cm.jet)
m.drawparallels(np.arange(-90.,80.,5.),labels=[1,0,0,0])
m.drawmeridians(np.arange(-180.,180.,5.),labels=[0,0,0,1])
plt.colorbar(cs,orientation='vertical')
plt.title('Precipitation Plot')
plt.show()