2016-08-29 196 views
1

考慮到可用的形狀文件here:我知道可以生成我需要的縣級標籤以及地圖上某些點(如下所示)所需的基本地圖。我遇到的問題是我似乎無法用figsize控制圖形的大小。 這是我有:MatPlotLib + GeoPandas:繪製多個圖層,控制圖形

import geopandas as gpd 
import matplotlib.pyplot as plt 
%matplotlib inline 
figsize=5,5 
fig = plt.figure(figsize=(figsize),dpi=300) 

shpfileshpfile=r'Y:\HQ\TH\Groups\NR\PSPD\Input\US_Counties\cb_2015_us_county_20m.shp' 
c=gpd.read_file(shpfile) 
c=c.loc[c['GEOID'].isin(['26161','26093','26049','26091','26075','26125','26163','26099','26115','26065'])] 
c['coords'] = c['geometry'].apply(lambda x: x.representative_point().coords[:]) 
c['coords'] = [coords[0] for coords in c['coords']] 
ax=c.plot() 

#Control some attributes regarding the axis (for the plot above) 

ax.spines['top'].set_visible(False);ax.spines['bottom'].set_visible(False);ax.spines['left'].set_visible(False);ax.spines['right'].set_visible(False) 
    ax.tick_params(axis='y',which='both',left='off',right='off',color='none',labelcolor='none') 
    ax.tick_params(axis='x',which='both',top='off',bottom='off',color='none',labelcolor='none') 
    for idx, row in c.iterrows(): 
     ax.annotate(s=row['NAME'], xy=row['coords'], 
        horizontalalignment='center') 
lat2=[42.5,42.3] 
lon2=[-84,-83.5] 

    #Add another plot... 

ax.plot(lon2,lat2,alpha=1,marker='o',linestyle='none',markeredgecolor='none',markersize=15,color='white') 
plt.show() 

正如你可以看到,我選擇調用由軸名稱情節,因爲我需要控制軸的屬性,如tick_params。我不確定是否有更好的方法。這看起來像一個「無腦」,但我似乎無法弄清楚爲什麼我無法控制數字大小。

提前致謝!

回答

1

我必須做到以下幾點:

  1. 使用fig, ax = plt.subplots(1, 1, figsize = (figsize))

2.使用在c.plot斧頭= A()的參數

import geopandas as gpd 
import matplotlib.pyplot as plt 
%matplotlib inline 
figsize=5,5 
#fig = plt.figure(figsize=(figsize),dpi=300) 
#ax = fig.add_subplot(111) 
fig, ax = plt.subplots(1, 1, figsize = (figsize)) 
shpfileshpfile=r'Y:\HQ\TH\Groups\NR\PSPD\Input\US_Counties\cb_2015_us_county_20m.shp' 
c=gpd.read_file(shpfile) 
c=c.loc[c['GEOID'].isin(['26161','26093','26049','26091','26075','26125','26163','26099','26115','26065'])] 
c['coords'] = c['geometry'].apply(lambda x: x.representative_point().coords[:]) 
c['coords'] = [coords[0] for coords in c['coords']] 
c.plot(ax=ax) 
ax.spines['top'].set_visible(False);ax.spines['bottom'].set_visible(False);ax.spines['left'].set_visible(False);ax.spines['right'].set_visible(False) 
ax.tick_params(axis='y',which='both',left='off',right='off',color='none',labelcolor='none') 
ax.tick_params(axis='x',which='both',top='off',bottom='off',color='none',labelcolor='none') 
for idx, row in c.iterrows(): 
    ax.annotate(s=row['NAME'], xy=row['coords'], 
       horizontalalignment='center') 
lat2=[42.5,42.3] 
lon2=[-84,-83.5] 
ax.plot(lon2,lat2,alpha=1,marker='o',linestyle='none',markeredgecolor='none',markersize=15,color='white')